1// Code generated by smithy-go-codegen DO NOT EDIT.
2
3package ses
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/ses/types"
10	"github.com/aws/smithy-go/middleware"
11	smithyhttp "github.com/aws/smithy-go/transport/http"
12)
13
14// Provides sending statistics for the current AWS Region. The result is a list of
15// data points, representing the last two weeks of sending activity. Each data
16// point in the list contains statistics for a 15-minute period of time. You can
17// execute this operation no more than once per second.
18func (c *Client) GetSendStatistics(ctx context.Context, params *GetSendStatisticsInput, optFns ...func(*Options)) (*GetSendStatisticsOutput, error) {
19	if params == nil {
20		params = &GetSendStatisticsInput{}
21	}
22
23	result, metadata, err := c.invokeOperation(ctx, "GetSendStatistics", params, optFns, addOperationGetSendStatisticsMiddlewares)
24	if err != nil {
25		return nil, err
26	}
27
28	out := result.(*GetSendStatisticsOutput)
29	out.ResultMetadata = metadata
30	return out, nil
31}
32
33type GetSendStatisticsInput struct {
34}
35
36// Represents a list of data points. This list contains aggregated data from the
37// previous two weeks of your sending activity with Amazon SES.
38type GetSendStatisticsOutput struct {
39
40	// A list of data points, each of which represents 15 minutes of activity.
41	SendDataPoints []types.SendDataPoint
42
43	// Metadata pertaining to the operation's result.
44	ResultMetadata middleware.Metadata
45}
46
47func addOperationGetSendStatisticsMiddlewares(stack *middleware.Stack, options Options) (err error) {
48	err = stack.Serialize.Add(&awsAwsquery_serializeOpGetSendStatistics{}, middleware.After)
49	if err != nil {
50		return err
51	}
52	err = stack.Deserialize.Add(&awsAwsquery_deserializeOpGetSendStatistics{}, middleware.After)
53	if err != nil {
54		return err
55	}
56	if err = addSetLoggerMiddleware(stack, options); err != nil {
57		return err
58	}
59	if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil {
60		return err
61	}
62	if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil {
63		return err
64	}
65	if err = addResolveEndpointMiddleware(stack, options); err != nil {
66		return err
67	}
68	if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil {
69		return err
70	}
71	if err = addRetryMiddlewares(stack, options); err != nil {
72		return err
73	}
74	if err = addHTTPSignerV4Middleware(stack, options); err != nil {
75		return err
76	}
77	if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil {
78		return err
79	}
80	if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil {
81		return err
82	}
83	if err = addClientUserAgent(stack); err != nil {
84		return err
85	}
86	if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
87		return err
88	}
89	if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
90		return err
91	}
92	if err = stack.Initialize.Add(newServiceMetadataMiddleware_opGetSendStatistics(options.Region), middleware.Before); err != nil {
93		return err
94	}
95	if err = addRequestIDRetrieverMiddleware(stack); err != nil {
96		return err
97	}
98	if err = addResponseErrorMiddleware(stack); err != nil {
99		return err
100	}
101	if err = addRequestResponseLogging(stack, options); err != nil {
102		return err
103	}
104	return nil
105}
106
107func newServiceMetadataMiddleware_opGetSendStatistics(region string) *awsmiddleware.RegisterServiceMetadata {
108	return &awsmiddleware.RegisterServiceMetadata{
109		Region:        region,
110		ServiceID:     ServiceID,
111		SigningName:   "ses",
112		OperationName: "GetSendStatistics",
113	}
114}
115