1// Code generated by smithy-go-codegen DO NOT EDIT. 2 3package acmpca 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/aws-sdk-go-v2/service/acmpca/types" 10 "github.com/aws/smithy-go/middleware" 11 smithyhttp "github.com/aws/smithy-go/transport/http" 12) 13 14// Adds one or more tags to your private CA. Tags are labels that you can use to 15// identify and organize your AWS resources. Each tag consists of a key and an 16// optional value. You specify the private CA on input by its Amazon Resource Name 17// (ARN). You specify the tag by using a key-value pair. You can apply a tag to 18// just one private CA if you want to identify a specific characteristic of that 19// CA, or you can apply the same tag to multiple private CAs if you want to filter 20// for a common relationship among those CAs. To remove one or more tags, use the 21// UntagCertificateAuthority 22// (https://docs.aws.amazon.com/acm-pca/latest/APIReference/API_UntagCertificateAuthority.html) 23// action. Call the ListTags 24// (https://docs.aws.amazon.com/acm-pca/latest/APIReference/API_ListTags.html) 25// action to see what tags are associated with your CA. 26func (c *Client) TagCertificateAuthority(ctx context.Context, params *TagCertificateAuthorityInput, optFns ...func(*Options)) (*TagCertificateAuthorityOutput, error) { 27 if params == nil { 28 params = &TagCertificateAuthorityInput{} 29 } 30 31 result, metadata, err := c.invokeOperation(ctx, "TagCertificateAuthority", params, optFns, addOperationTagCertificateAuthorityMiddlewares) 32 if err != nil { 33 return nil, err 34 } 35 36 out := result.(*TagCertificateAuthorityOutput) 37 out.ResultMetadata = metadata 38 return out, nil 39} 40 41type TagCertificateAuthorityInput struct { 42 43 // The Amazon Resource Name (ARN) that was returned when you called 44 // CreateCertificateAuthority 45 // (https://docs.aws.amazon.com/acm-pca/latest/APIReference/API_CreateCertificateAuthority.html). 46 // This must be of the form: 47 // arn:aws:acm-pca:region:account:certificate-authority/12345678-1234-1234-1234-123456789012 48 // 49 // This member is required. 50 CertificateAuthorityArn *string 51 52 // List of tags to be associated with the CA. 53 // 54 // This member is required. 55 Tags []types.Tag 56} 57 58type TagCertificateAuthorityOutput struct { 59 // Metadata pertaining to the operation's result. 60 ResultMetadata middleware.Metadata 61} 62 63func addOperationTagCertificateAuthorityMiddlewares(stack *middleware.Stack, options Options) (err error) { 64 err = stack.Serialize.Add(&awsAwsjson11_serializeOpTagCertificateAuthority{}, middleware.After) 65 if err != nil { 66 return err 67 } 68 err = stack.Deserialize.Add(&awsAwsjson11_deserializeOpTagCertificateAuthority{}, middleware.After) 69 if err != nil { 70 return err 71 } 72 if err = addSetLoggerMiddleware(stack, options); err != nil { 73 return err 74 } 75 if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil { 76 return err 77 } 78 if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil { 79 return err 80 } 81 if err = addResolveEndpointMiddleware(stack, options); err != nil { 82 return err 83 } 84 if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil { 85 return err 86 } 87 if err = addRetryMiddlewares(stack, options); err != nil { 88 return err 89 } 90 if err = addHTTPSignerV4Middleware(stack, options); err != nil { 91 return err 92 } 93 if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil { 94 return err 95 } 96 if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil { 97 return err 98 } 99 if err = addClientUserAgent(stack); err != nil { 100 return err 101 } 102 if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil { 103 return err 104 } 105 if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil { 106 return err 107 } 108 if err = addOpTagCertificateAuthorityValidationMiddleware(stack); err != nil { 109 return err 110 } 111 if err = stack.Initialize.Add(newServiceMetadataMiddleware_opTagCertificateAuthority(options.Region), middleware.Before); err != nil { 112 return err 113 } 114 if err = addRequestIDRetrieverMiddleware(stack); err != nil { 115 return err 116 } 117 if err = addResponseErrorMiddleware(stack); err != nil { 118 return err 119 } 120 if err = addRequestResponseLogging(stack, options); err != nil { 121 return err 122 } 123 return nil 124} 125 126func newServiceMetadataMiddleware_opTagCertificateAuthority(region string) *awsmiddleware.RegisterServiceMetadata { 127 return &awsmiddleware.RegisterServiceMetadata{ 128 Region: region, 129 ServiceID: ServiceID, 130 SigningName: "acm-pca", 131 OperationName: "TagCertificateAuthority", 132 } 133} 134