1// Code generated by smithy-go-codegen DO NOT EDIT.
2
3package cloudsearch
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/cloudsearch/types"
10	"github.com/aws/smithy-go/middleware"
11	smithyhttp "github.com/aws/smithy-go/transport/http"
12)
13
14// Gets information about the access policies that control access to the domain's
15// document and search endpoints. By default, shows the configuration with any
16// pending changes. Set the Deployed option to true to show the active
17// configuration and exclude pending changes. For more information, see Configuring
18// Access for a Search Domain
19// (http://docs.aws.amazon.com/cloudsearch/latest/developerguide/configuring-access.html)
20// in the Amazon CloudSearch Developer Guide.
21func (c *Client) DescribeServiceAccessPolicies(ctx context.Context, params *DescribeServiceAccessPoliciesInput, optFns ...func(*Options)) (*DescribeServiceAccessPoliciesOutput, error) {
22	if params == nil {
23		params = &DescribeServiceAccessPoliciesInput{}
24	}
25
26	result, metadata, err := c.invokeOperation(ctx, "DescribeServiceAccessPolicies", params, optFns, addOperationDescribeServiceAccessPoliciesMiddlewares)
27	if err != nil {
28		return nil, err
29	}
30
31	out := result.(*DescribeServiceAccessPoliciesOutput)
32	out.ResultMetadata = metadata
33	return out, nil
34}
35
36// Container for the parameters to the DescribeServiceAccessPolicies operation.
37// Specifies the name of the domain you want to describe. To show the active
38// configuration and exclude any pending changes, set the Deployed option to true.
39type DescribeServiceAccessPoliciesInput struct {
40
41	// The name of the domain you want to describe.
42	//
43	// This member is required.
44	DomainName *string
45
46	// Whether to display the deployed configuration (true) or include any pending
47	// changes (false). Defaults to false.
48	Deployed *bool
49}
50
51// The result of a DescribeServiceAccessPolicies request.
52type DescribeServiceAccessPoliciesOutput struct {
53
54	// The access rules configured for the domain specified in the request.
55	//
56	// This member is required.
57	AccessPolicies *types.AccessPoliciesStatus
58
59	// Metadata pertaining to the operation's result.
60	ResultMetadata middleware.Metadata
61}
62
63func addOperationDescribeServiceAccessPoliciesMiddlewares(stack *middleware.Stack, options Options) (err error) {
64	err = stack.Serialize.Add(&awsAwsquery_serializeOpDescribeServiceAccessPolicies{}, middleware.After)
65	if err != nil {
66		return err
67	}
68	err = stack.Deserialize.Add(&awsAwsquery_deserializeOpDescribeServiceAccessPolicies{}, 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 = addOpDescribeServiceAccessPoliciesValidationMiddleware(stack); err != nil {
109		return err
110	}
111	if err = stack.Initialize.Add(newServiceMetadataMiddleware_opDescribeServiceAccessPolicies(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_opDescribeServiceAccessPolicies(region string) *awsmiddleware.RegisterServiceMetadata {
127	return &awsmiddleware.RegisterServiceMetadata{
128		Region:        region,
129		ServiceID:     ServiceID,
130		SigningName:   "cloudsearch",
131		OperationName: "DescribeServiceAccessPolicies",
132	}
133}
134