Skip to content

Commit

Permalink
Merge pull request #26944 from BenGisc/f-identitystore-groupmembership
Browse files Browse the repository at this point in the history
[New Resource] aws_identitystore_group_membership
  • Loading branch information
ewbankkit committed Sep 28, 2022
2 parents dcf46e2 + 2b4263b commit b95b99a
Show file tree
Hide file tree
Showing 5 changed files with 535 additions and 2 deletions.
3 changes: 3 additions & 0 deletions .changelog/26944.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
```release-note:new-resource
aws_identitystore_group_membership
```
5 changes: 3 additions & 2 deletions internal/provider/provider.go
Original file line number Diff line number Diff line change
Expand Up @@ -1603,8 +1603,9 @@ func New(_ context.Context) (*schema.Provider, error) {
"aws_iam_user_ssh_key": iam.ResourceUserSSHKey(),
"aws_iam_virtual_mfa_device": iam.ResourceVirtualMFADevice(),

"aws_identitystore_group": identitystore.ResourceGroup(),
"aws_identitystore_user": identitystore.ResourceUser(),
"aws_identitystore_group": identitystore.ResourceGroup(),
"aws_identitystore_user": identitystore.ResourceUser(),
"aws_identitystore_group_membership": identitystore.ResourceGroupMembership(),

"aws_imagebuilder_component": imagebuilder.ResourceComponent(),
"aws_imagebuilder_container_recipe": imagebuilder.ResourceContainerRecipe(),
Expand Down
205 changes: 205 additions & 0 deletions internal/service/identitystore/group_membership.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,205 @@
package identitystore

import (
"context"
"errors"
"fmt"
"log"
"strings"

"github.com/aws/aws-sdk-go-v2/aws"
"github.com/aws/aws-sdk-go-v2/service/identitystore"
"github.com/aws/aws-sdk-go-v2/service/identitystore/types"
"github.com/hashicorp/terraform-plugin-sdk/v2/diag"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource"
"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/create"
"github.com/hashicorp/terraform-provider-aws/internal/tfresource"
"github.com/hashicorp/terraform-provider-aws/names"
)

const (
ResNameGroupMembership = "GroupMembership"
)

func ResourceGroupMembership() *schema.Resource {
return &schema.Resource{
CreateContext: resourceGroupMembershipCreate,
ReadContext: resourceGroupMembershipRead,
DeleteContext: resourceGroupMembershipDelete,

Importer: &schema.ResourceImporter{
StateContext: schema.ImportStatePassthroughContext,
},

Schema: map[string]*schema.Schema{
"group_id": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
ValidateFunc: validation.StringLenBetween(1, 47),
},

"identity_store_id": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
ValidateFunc: validation.StringLenBetween(1, 36),
},

"member_id": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
ValidateFunc: validation.StringLenBetween(1, 47),
},

"membership_id": {
Type: schema.TypeString,
Computed: true,
},
},
}
}

func resourceGroupMembershipCreate(ctx context.Context, d *schema.ResourceData, meta interface{}) diag.Diagnostics {
conn := meta.(*conns.AWSClient).IdentityStoreConn

identityStoreId := d.Get("identity_store_id").(string)

input := &identitystore.CreateGroupMembershipInput{
IdentityStoreId: aws.String(identityStoreId),
}

if v, ok := d.GetOk("group_id"); ok {
input.GroupId = aws.String(v.(string))
}
if v, ok := d.GetOk("member_id"); ok {
input.MemberId = &types.MemberIdMemberUserId{Value: v.(string)}
}

out, err := conn.CreateGroupMembership(ctx, input)
if err != nil {
return create.DiagError(names.IdentityStore, create.ErrActionCreating, ResNameGroupMembership, d.Get("identity_store_id").(string), err)
}
if out == nil || out.MembershipId == nil {
return create.DiagError(names.IdentityStore, create.ErrActionCreating, ResNameGroupMembership, d.Get("identity_store_id").(string), errors.New("empty output"))
}

d.Set("membership_id", out.MembershipId)
d.SetId(fmt.Sprintf("%s/%s", aws.ToString(out.IdentityStoreId), aws.ToString(out.MembershipId)))

return resourceGroupMembershipRead(ctx, d, meta)
}

func resourceGroupMembershipRead(ctx context.Context, d *schema.ResourceData, meta interface{}) diag.Diagnostics {
conn := meta.(*conns.AWSClient).IdentityStoreConn

identityStoreId, groupMembershipId, err := resourceGroupMembershipParseID(d.Id())

if err != nil {
return create.DiagError(names.IdentityStore, create.ErrActionReading, ResNameGroupMembership, d.Id(), err)
}

out, err := findGroupMembershipByID(ctx, conn, identityStoreId, groupMembershipId)

if !d.IsNewResource() && tfresource.NotFound(err) {
log.Printf("[WARN] IdentityStore GroupMembership (%s) not found, removing from state", d.Id())
d.SetId("")
return nil
}

if err != nil {
return create.DiagError(names.IdentityStore, create.ErrActionReading, ResNameGroupMembership, d.Id(), err)
}

d.Set("group_id", out.GroupId)
d.Set("identity_store_id", out.IdentityStoreId)

memberId, err := getMemberIdMemberUserId(out.MemberId)

if err != nil {
return create.DiagError(names.IdentityStore, create.ErrActionReading, ResNameGroupMembership, d.Id(), err)
}

d.Set("member_id", memberId)
d.Set("membership_id", out.MembershipId)

return nil
}

func resourceGroupMembershipDelete(ctx context.Context, d *schema.ResourceData, meta interface{}) diag.Diagnostics {
conn := meta.(*conns.AWSClient).IdentityStoreConn

log.Printf("[INFO] Deleting IdentityStore GroupMembership %s", d.Id())

input := &identitystore.DeleteGroupMembershipInput{
MembershipId: aws.String(d.Get("membership_id").(string)),
IdentityStoreId: aws.String(d.Get("identity_store_id").(string)),
}

_, err := conn.DeleteGroupMembership(ctx, input)
if err != nil {
var nfe *types.ResourceNotFoundException
if errors.As(err, &nfe) {
return nil
}

return create.DiagError(names.IdentityStore, create.ErrActionDeleting, ResNameGroupMembership, d.Id(), err)
}

return nil
}

func getMemberIdMemberUserId(memberId types.MemberId) (*string, error) {
switch v := memberId.(type) {
case *types.MemberIdMemberUserId:
return &v.Value, nil

case *types.UnknownUnionMember:
return nil, errors.New("expected a user id, got unknown type id")

default:
return nil, errors.New("expected a user id, got unknown type id")
}
}

func resourceGroupMembershipParseID(id string) (identityStoreId, groupMembershipId string, err error) {
parts := strings.Split(id, "/")

if len(parts) != 2 || parts[0] == "" || parts[1] == "" {
err = errors.New("expected a resource id in the form: identity-store-id/group-membership-id")
return
}

return parts[0], parts[1], nil
}

func findGroupMembershipByID(ctx context.Context, conn *identitystore.Client, identityStoreId, groupMembershipId string) (*identitystore.DescribeGroupMembershipOutput, error) {
in := &identitystore.DescribeGroupMembershipInput{
IdentityStoreId: aws.String(identityStoreId),
MembershipId: aws.String(groupMembershipId),
}

out, err := conn.DescribeGroupMembership(ctx, in)

if err != nil {
var e *types.ResourceNotFoundException
if errors.As(err, &e) {
return nil, &resource.NotFoundError{
LastError: err,
LastRequest: in,
}
} else {
return nil, err
}
}

if out == nil || out.MembershipId == nil {
return nil, tfresource.NewEmptyResultError(in)
}

return out, nil
}
Loading

0 comments on commit b95b99a

Please sign in to comment.