1// Code generated by smithy-go-codegen DO NOT EDIT. 2 3package iam 4 5import ( 6 "context" 7 awsmiddleware "github.com/aws/aws-sdk-go-v2/aws/middleware" 8 "github.com/aws/aws-sdk-go-v2/aws/signer/v4" 9 "github.com/aws/smithy-go/middleware" 10 smithyhttp "github.com/aws/smithy-go/transport/http" 11) 12 13// Submits a service-linked role deletion request and returns a DeletionTaskId, 14// which you can use to check the status of the deletion. Before you call this 15// operation, confirm that the role has no active sessions and that any resources 16// used by the role in the linked service are deleted. If you call this operation 17// more than once for the same service-linked role and an earlier deletion task is 18// not complete, then the DeletionTaskId of the earlier request is returned. If you 19// submit a deletion request for a service-linked role whose linked service is 20// still accessing a resource, then the deletion task fails. If it fails, the 21// GetServiceLinkedRoleDeletionStatus API operation returns the reason for the 22// failure, usually including the resources that must be deleted. To delete the 23// service-linked role, you must first remove those resources from the linked 24// service and then submit the deletion request again. Resources are specific to 25// the service that is linked to the role. For more information about removing 26// resources from a service, see the AWS documentation 27// (http://docs.aws.amazon.com/) for your service. For more information about 28// service-linked roles, see Roles Terms and Concepts: AWS Service-Linked Role 29// (https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_terms-and-concepts.html#iam-term-service-linked-role) 30// in the IAM User Guide. 31func (c *Client) DeleteServiceLinkedRole(ctx context.Context, params *DeleteServiceLinkedRoleInput, optFns ...func(*Options)) (*DeleteServiceLinkedRoleOutput, error) { 32 if params == nil { 33 params = &DeleteServiceLinkedRoleInput{} 34 } 35 36 result, metadata, err := c.invokeOperation(ctx, "DeleteServiceLinkedRole", params, optFns, addOperationDeleteServiceLinkedRoleMiddlewares) 37 if err != nil { 38 return nil, err 39 } 40 41 out := result.(*DeleteServiceLinkedRoleOutput) 42 out.ResultMetadata = metadata 43 return out, nil 44} 45 46type DeleteServiceLinkedRoleInput struct { 47 48 // The name of the service-linked role to be deleted. 49 // 50 // This member is required. 51 RoleName *string 52} 53 54type DeleteServiceLinkedRoleOutput struct { 55 56 // The deletion task identifier that you can use to check the status of the 57 // deletion. This identifier is returned in the format task/aws-service-role///. 58 // 59 // This member is required. 60 DeletionTaskId *string 61 62 // Metadata pertaining to the operation's result. 63 ResultMetadata middleware.Metadata 64} 65 66func addOperationDeleteServiceLinkedRoleMiddlewares(stack *middleware.Stack, options Options) (err error) { 67 err = stack.Serialize.Add(&awsAwsquery_serializeOpDeleteServiceLinkedRole{}, middleware.After) 68 if err != nil { 69 return err 70 } 71 err = stack.Deserialize.Add(&awsAwsquery_deserializeOpDeleteServiceLinkedRole{}, middleware.After) 72 if err != nil { 73 return err 74 } 75 if err = addSetLoggerMiddleware(stack, options); err != nil { 76 return err 77 } 78 if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil { 79 return err 80 } 81 if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil { 82 return err 83 } 84 if err = addResolveEndpointMiddleware(stack, options); err != nil { 85 return err 86 } 87 if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil { 88 return err 89 } 90 if err = addRetryMiddlewares(stack, options); err != nil { 91 return err 92 } 93 if err = addHTTPSignerV4Middleware(stack, options); err != nil { 94 return err 95 } 96 if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil { 97 return err 98 } 99 if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil { 100 return err 101 } 102 if err = addClientUserAgent(stack); err != nil { 103 return err 104 } 105 if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil { 106 return err 107 } 108 if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil { 109 return err 110 } 111 if err = addOpDeleteServiceLinkedRoleValidationMiddleware(stack); err != nil { 112 return err 113 } 114 if err = stack.Initialize.Add(newServiceMetadataMiddleware_opDeleteServiceLinkedRole(options.Region), middleware.Before); err != nil { 115 return err 116 } 117 if err = addRequestIDRetrieverMiddleware(stack); err != nil { 118 return err 119 } 120 if err = addResponseErrorMiddleware(stack); err != nil { 121 return err 122 } 123 if err = addRequestResponseLogging(stack, options); err != nil { 124 return err 125 } 126 return nil 127} 128 129func newServiceMetadataMiddleware_opDeleteServiceLinkedRole(region string) *awsmiddleware.RegisterServiceMetadata { 130 return &awsmiddleware.RegisterServiceMetadata{ 131 Region: region, 132 ServiceID: ServiceID, 133 SigningName: "iam", 134 OperationName: "DeleteServiceLinkedRole", 135 } 136} 137