1// Code generated by smithy-go-codegen DO NOT EDIT.
2
3package ec2
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/ec2/types"
10	"github.com/aws/smithy-go/middleware"
11	smithyhttp "github.com/aws/smithy-go/transport/http"
12)
13
14// Creates a new version for a launch template. You can specify an existing version
15// of launch template from which to base the new version. Launch template versions
16// are numbered in the order in which they are created. You cannot specify, change,
17// or replace the numbering of launch template versions. For more information, see
18// Managing launch template versions
19// (https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-launch-templates.html#manage-launch-template-versions)in
20// the Amazon Elastic Compute Cloud User Guide.
21func (c *Client) CreateLaunchTemplateVersion(ctx context.Context, params *CreateLaunchTemplateVersionInput, optFns ...func(*Options)) (*CreateLaunchTemplateVersionOutput, error) {
22	if params == nil {
23		params = &CreateLaunchTemplateVersionInput{}
24	}
25
26	result, metadata, err := c.invokeOperation(ctx, "CreateLaunchTemplateVersion", params, optFns, addOperationCreateLaunchTemplateVersionMiddlewares)
27	if err != nil {
28		return nil, err
29	}
30
31	out := result.(*CreateLaunchTemplateVersionOutput)
32	out.ResultMetadata = metadata
33	return out, nil
34}
35
36type CreateLaunchTemplateVersionInput struct {
37
38	// The information for the launch template.
39	//
40	// This member is required.
41	LaunchTemplateData *types.RequestLaunchTemplateData
42
43	// Unique, case-sensitive identifier you provide to ensure the idempotency of the
44	// request. For more information, see Ensuring Idempotency
45	// (https://docs.aws.amazon.com/AWSEC2/latest/APIReference/Run_Instance_Idempotency.html).
46	// Constraint: Maximum 128 ASCII characters.
47	ClientToken *string
48
49	// Checks whether you have the required permissions for the action, without
50	// actually making the request, and provides an error response. If you have the
51	// required permissions, the error response is DryRunOperation. Otherwise, it is
52	// UnauthorizedOperation.
53	DryRun bool
54
55	// The ID of the launch template. You must specify either the launch template ID or
56	// launch template name in the request.
57	LaunchTemplateId *string
58
59	// The name of the launch template. You must specify either the launch template ID
60	// or launch template name in the request.
61	LaunchTemplateName *string
62
63	// The version number of the launch template version on which to base the new
64	// version. The new version inherits the same launch parameters as the source
65	// version, except for parameters that you specify in LaunchTemplateData. Snapshots
66	// applied to the block device mapping are ignored when creating a new version
67	// unless they are explicitly included.
68	SourceVersion *string
69
70	// A description for the version of the launch template.
71	VersionDescription *string
72}
73
74type CreateLaunchTemplateVersionOutput struct {
75
76	// Information about the launch template version.
77	LaunchTemplateVersion *types.LaunchTemplateVersion
78
79	// If the new version of the launch template contains parameters or parameter
80	// combinations that are not valid, an error code and an error message are returned
81	// for each issue that's found.
82	Warning *types.ValidationWarning
83
84	// Metadata pertaining to the operation's result.
85	ResultMetadata middleware.Metadata
86}
87
88func addOperationCreateLaunchTemplateVersionMiddlewares(stack *middleware.Stack, options Options) (err error) {
89	err = stack.Serialize.Add(&awsEc2query_serializeOpCreateLaunchTemplateVersion{}, middleware.After)
90	if err != nil {
91		return err
92	}
93	err = stack.Deserialize.Add(&awsEc2query_deserializeOpCreateLaunchTemplateVersion{}, middleware.After)
94	if err != nil {
95		return err
96	}
97	if err = addSetLoggerMiddleware(stack, options); err != nil {
98		return err
99	}
100	if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil {
101		return err
102	}
103	if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil {
104		return err
105	}
106	if err = addResolveEndpointMiddleware(stack, options); err != nil {
107		return err
108	}
109	if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil {
110		return err
111	}
112	if err = addRetryMiddlewares(stack, options); err != nil {
113		return err
114	}
115	if err = addHTTPSignerV4Middleware(stack, options); err != nil {
116		return err
117	}
118	if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil {
119		return err
120	}
121	if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil {
122		return err
123	}
124	if err = addClientUserAgent(stack); err != nil {
125		return err
126	}
127	if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
128		return err
129	}
130	if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
131		return err
132	}
133	if err = addOpCreateLaunchTemplateVersionValidationMiddleware(stack); err != nil {
134		return err
135	}
136	if err = stack.Initialize.Add(newServiceMetadataMiddleware_opCreateLaunchTemplateVersion(options.Region), middleware.Before); err != nil {
137		return err
138	}
139	if err = addRequestIDRetrieverMiddleware(stack); err != nil {
140		return err
141	}
142	if err = addResponseErrorMiddleware(stack); err != nil {
143		return err
144	}
145	if err = addRequestResponseLogging(stack, options); err != nil {
146		return err
147	}
148	return nil
149}
150
151func newServiceMetadataMiddleware_opCreateLaunchTemplateVersion(region string) *awsmiddleware.RegisterServiceMetadata {
152	return &awsmiddleware.RegisterServiceMetadata{
153		Region:        region,
154		ServiceID:     ServiceID,
155		SigningName:   "ec2",
156		OperationName: "CreateLaunchTemplateVersion",
157	}
158}
159