1// Code generated by smithy-go-codegen DO NOT EDIT. 2 3package configservice 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/configservice/types" 10 "github.com/aws/smithy-go/middleware" 11 smithyhttp "github.com/aws/smithy-go/transport/http" 12) 13 14// Returns the number of resources that are compliant and the number that are 15// noncompliant. You can specify one or more resource types to get these numbers 16// for each resource type. The maximum number returned is 100. 17func (c *Client) GetComplianceSummaryByResourceType(ctx context.Context, params *GetComplianceSummaryByResourceTypeInput, optFns ...func(*Options)) (*GetComplianceSummaryByResourceTypeOutput, error) { 18 if params == nil { 19 params = &GetComplianceSummaryByResourceTypeInput{} 20 } 21 22 result, metadata, err := c.invokeOperation(ctx, "GetComplianceSummaryByResourceType", params, optFns, addOperationGetComplianceSummaryByResourceTypeMiddlewares) 23 if err != nil { 24 return nil, err 25 } 26 27 out := result.(*GetComplianceSummaryByResourceTypeOutput) 28 out.ResultMetadata = metadata 29 return out, nil 30} 31 32// 33type GetComplianceSummaryByResourceTypeInput struct { 34 35 // Specify one or more resource types to get the number of resources that are 36 // compliant and the number that are noncompliant for each resource type. For this 37 // request, you can specify an AWS resource type such as AWS::EC2::Instance. You 38 // can specify that the resource type is an AWS account by specifying 39 // AWS::::Account. 40 ResourceTypes []string 41} 42 43// 44type GetComplianceSummaryByResourceTypeOutput struct { 45 46 // The number of resources that are compliant and the number that are noncompliant. 47 // If one or more resource types were provided with the request, the numbers are 48 // returned for each resource type. The maximum number returned is 100. 49 ComplianceSummariesByResourceType []types.ComplianceSummaryByResourceType 50 51 // Metadata pertaining to the operation's result. 52 ResultMetadata middleware.Metadata 53} 54 55func addOperationGetComplianceSummaryByResourceTypeMiddlewares(stack *middleware.Stack, options Options) (err error) { 56 err = stack.Serialize.Add(&awsAwsjson11_serializeOpGetComplianceSummaryByResourceType{}, middleware.After) 57 if err != nil { 58 return err 59 } 60 err = stack.Deserialize.Add(&awsAwsjson11_deserializeOpGetComplianceSummaryByResourceType{}, middleware.After) 61 if err != nil { 62 return err 63 } 64 if err = addSetLoggerMiddleware(stack, options); err != nil { 65 return err 66 } 67 if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil { 68 return err 69 } 70 if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil { 71 return err 72 } 73 if err = addResolveEndpointMiddleware(stack, options); err != nil { 74 return err 75 } 76 if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil { 77 return err 78 } 79 if err = addRetryMiddlewares(stack, options); err != nil { 80 return err 81 } 82 if err = addHTTPSignerV4Middleware(stack, options); err != nil { 83 return err 84 } 85 if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil { 86 return err 87 } 88 if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil { 89 return err 90 } 91 if err = addClientUserAgent(stack); err != nil { 92 return err 93 } 94 if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil { 95 return err 96 } 97 if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil { 98 return err 99 } 100 if err = stack.Initialize.Add(newServiceMetadataMiddleware_opGetComplianceSummaryByResourceType(options.Region), middleware.Before); err != nil { 101 return err 102 } 103 if err = addRequestIDRetrieverMiddleware(stack); err != nil { 104 return err 105 } 106 if err = addResponseErrorMiddleware(stack); err != nil { 107 return err 108 } 109 if err = addRequestResponseLogging(stack, options); err != nil { 110 return err 111 } 112 return nil 113} 114 115func newServiceMetadataMiddleware_opGetComplianceSummaryByResourceType(region string) *awsmiddleware.RegisterServiceMetadata { 116 return &awsmiddleware.RegisterServiceMetadata{ 117 Region: region, 118 ServiceID: ServiceID, 119 SigningName: "config", 120 OperationName: "GetComplianceSummaryByResourceType", 121 } 122} 123