code.dwrz.net

Go monorepo.
Log | Files | Refs

api_op_CreateTrafficPolicy.go (4296B)


      1 // Code generated by smithy-go-codegen DO NOT EDIT.
      2 
      3 package route53
      4 
      5 import (
      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/route53/types"
     10 	"github.com/aws/smithy-go/middleware"
     11 	smithyhttp "github.com/aws/smithy-go/transport/http"
     12 )
     13 
     14 // Creates a traffic policy, which you use to create multiple DNS resource record
     15 // sets for one domain name (such as example.com) or one subdomain name (such as
     16 // www.example.com).
     17 func (c *Client) CreateTrafficPolicy(ctx context.Context, params *CreateTrafficPolicyInput, optFns ...func(*Options)) (*CreateTrafficPolicyOutput, error) {
     18 	if params == nil {
     19 		params = &CreateTrafficPolicyInput{}
     20 	}
     21 
     22 	result, metadata, err := c.invokeOperation(ctx, "CreateTrafficPolicy", params, optFns, c.addOperationCreateTrafficPolicyMiddlewares)
     23 	if err != nil {
     24 		return nil, err
     25 	}
     26 
     27 	out := result.(*CreateTrafficPolicyOutput)
     28 	out.ResultMetadata = metadata
     29 	return out, nil
     30 }
     31 
     32 // A complex type that contains information about the traffic policy that you want
     33 // to create.
     34 type CreateTrafficPolicyInput struct {
     35 
     36 	// The definition of this traffic policy in JSON format. For more information, see
     37 	// Traffic Policy Document Format
     38 	// (https://docs.aws.amazon.com/Route53/latest/APIReference/api-policies-traffic-policy-document-format.html).
     39 	//
     40 	// This member is required.
     41 	Document *string
     42 
     43 	// The name of the traffic policy.
     44 	//
     45 	// This member is required.
     46 	Name *string
     47 
     48 	// (Optional) Any comments that you want to include about the traffic policy.
     49 	Comment *string
     50 
     51 	noSmithyDocumentSerde
     52 }
     53 
     54 // A complex type that contains the response information for the
     55 // CreateTrafficPolicy request.
     56 type CreateTrafficPolicyOutput struct {
     57 
     58 	// A unique URL that represents a new traffic policy.
     59 	//
     60 	// This member is required.
     61 	Location *string
     62 
     63 	// A complex type that contains settings for the new traffic policy.
     64 	//
     65 	// This member is required.
     66 	TrafficPolicy *types.TrafficPolicy
     67 
     68 	// Metadata pertaining to the operation's result.
     69 	ResultMetadata middleware.Metadata
     70 
     71 	noSmithyDocumentSerde
     72 }
     73 
     74 func (c *Client) addOperationCreateTrafficPolicyMiddlewares(stack *middleware.Stack, options Options) (err error) {
     75 	err = stack.Serialize.Add(&awsRestxml_serializeOpCreateTrafficPolicy{}, middleware.After)
     76 	if err != nil {
     77 		return err
     78 	}
     79 	err = stack.Deserialize.Add(&awsRestxml_deserializeOpCreateTrafficPolicy{}, middleware.After)
     80 	if err != nil {
     81 		return err
     82 	}
     83 	if err = addSetLoggerMiddleware(stack, options); err != nil {
     84 		return err
     85 	}
     86 	if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil {
     87 		return err
     88 	}
     89 	if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil {
     90 		return err
     91 	}
     92 	if err = addResolveEndpointMiddleware(stack, options); err != nil {
     93 		return err
     94 	}
     95 	if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil {
     96 		return err
     97 	}
     98 	if err = addRetryMiddlewares(stack, options); err != nil {
     99 		return err
    100 	}
    101 	if err = addHTTPSignerV4Middleware(stack, options); err != nil {
    102 		return err
    103 	}
    104 	if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil {
    105 		return err
    106 	}
    107 	if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil {
    108 		return err
    109 	}
    110 	if err = addClientUserAgent(stack); err != nil {
    111 		return err
    112 	}
    113 	if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
    114 		return err
    115 	}
    116 	if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
    117 		return err
    118 	}
    119 	if err = addOpCreateTrafficPolicyValidationMiddleware(stack); err != nil {
    120 		return err
    121 	}
    122 	if err = stack.Initialize.Add(newServiceMetadataMiddleware_opCreateTrafficPolicy(options.Region), middleware.Before); err != nil {
    123 		return err
    124 	}
    125 	if err = addRequestIDRetrieverMiddleware(stack); err != nil {
    126 		return err
    127 	}
    128 	if err = addResponseErrorMiddleware(stack); err != nil {
    129 		return err
    130 	}
    131 	if err = addRequestResponseLogging(stack, options); err != nil {
    132 		return err
    133 	}
    134 	return nil
    135 }
    136 
    137 func newServiceMetadataMiddleware_opCreateTrafficPolicy(region string) *awsmiddleware.RegisterServiceMetadata {
    138 	return &awsmiddleware.RegisterServiceMetadata{
    139 		Region:        region,
    140 		ServiceID:     ServiceID,
    141 		SigningName:   "route53",
    142 		OperationName: "CreateTrafficPolicy",
    143 	}
    144 }