1// Code generated by smithy-go-codegen DO NOT EDIT.
2
3package kafka
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/kafka/types"
10	"github.com/aws/smithy-go/middleware"
11	smithyhttp "github.com/aws/smithy-go/transport/http"
12)
13
14// Returns a description of the MSK cluster whose Amazon Resource Name (ARN) is
15// specified in the request.
16func (c *Client) DescribeCluster(ctx context.Context, params *DescribeClusterInput, optFns ...func(*Options)) (*DescribeClusterOutput, error) {
17	if params == nil {
18		params = &DescribeClusterInput{}
19	}
20
21	result, metadata, err := c.invokeOperation(ctx, "DescribeCluster", params, optFns, addOperationDescribeClusterMiddlewares)
22	if err != nil {
23		return nil, err
24	}
25
26	out := result.(*DescribeClusterOutput)
27	out.ResultMetadata = metadata
28	return out, nil
29}
30
31type DescribeClusterInput struct {
32
33	// The Amazon Resource Name (ARN) that uniquely identifies the cluster.
34	//
35	// This member is required.
36	ClusterArn *string
37}
38
39type DescribeClusterOutput struct {
40
41	// The cluster information.
42	ClusterInfo *types.ClusterInfo
43
44	// Metadata pertaining to the operation's result.
45	ResultMetadata middleware.Metadata
46}
47
48func addOperationDescribeClusterMiddlewares(stack *middleware.Stack, options Options) (err error) {
49	err = stack.Serialize.Add(&awsRestjson1_serializeOpDescribeCluster{}, middleware.After)
50	if err != nil {
51		return err
52	}
53	err = stack.Deserialize.Add(&awsRestjson1_deserializeOpDescribeCluster{}, middleware.After)
54	if err != nil {
55		return err
56	}
57	if err = addSetLoggerMiddleware(stack, options); err != nil {
58		return err
59	}
60	if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil {
61		return err
62	}
63	if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil {
64		return err
65	}
66	if err = addResolveEndpointMiddleware(stack, options); err != nil {
67		return err
68	}
69	if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil {
70		return err
71	}
72	if err = addRetryMiddlewares(stack, options); err != nil {
73		return err
74	}
75	if err = addHTTPSignerV4Middleware(stack, options); err != nil {
76		return err
77	}
78	if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil {
79		return err
80	}
81	if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil {
82		return err
83	}
84	if err = addClientUserAgent(stack); err != nil {
85		return err
86	}
87	if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
88		return err
89	}
90	if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
91		return err
92	}
93	if err = addOpDescribeClusterValidationMiddleware(stack); err != nil {
94		return err
95	}
96	if err = stack.Initialize.Add(newServiceMetadataMiddleware_opDescribeCluster(options.Region), middleware.Before); err != nil {
97		return err
98	}
99	if err = addRequestIDRetrieverMiddleware(stack); err != nil {
100		return err
101	}
102	if err = addResponseErrorMiddleware(stack); err != nil {
103		return err
104	}
105	if err = addRequestResponseLogging(stack, options); err != nil {
106		return err
107	}
108	return nil
109}
110
111func newServiceMetadataMiddleware_opDescribeCluster(region string) *awsmiddleware.RegisterServiceMetadata {
112	return &awsmiddleware.RegisterServiceMetadata{
113		Region:        region,
114		ServiceID:     ServiceID,
115		SigningName:   "kafka",
116		OperationName: "DescribeCluster",
117	}
118}
119