/
CreateAutoScalingGroupCommand.ts
112 lines (102 loc) · 5.48 KB
/
CreateAutoScalingGroupCommand.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
import { getSerdePlugin } from "@aws-sdk/middleware-serde";
import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http";
import { Command as $Command } from "@aws-sdk/smithy-client";
import {
FinalizeHandlerArguments,
Handler,
HandlerExecutionContext,
HttpHandlerOptions as __HttpHandlerOptions,
MetadataBearer as __MetadataBearer,
MiddlewareStack,
SerdeContext as __SerdeContext,
} from "@aws-sdk/types";
import { AutoScalingClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../AutoScalingClient";
import { CreateAutoScalingGroupType } from "../models/models_0";
import {
deserializeAws_queryCreateAutoScalingGroupCommand,
serializeAws_queryCreateAutoScalingGroupCommand,
} from "../protocols/Aws_query";
export interface CreateAutoScalingGroupCommandInput extends CreateAutoScalingGroupType {}
export interface CreateAutoScalingGroupCommandOutput extends __MetadataBearer {}
/**
* <p>
* <b>We strongly recommend using a launch template when calling this operation to ensure full functionality for Amazon EC2 Auto Scaling and Amazon EC2.</b>
* </p>
* <p>Creates an Auto Scaling group with the specified name and attributes. </p>
* <p>If you exceed your maximum limit of Auto Scaling groups, the call fails. To query this limit,
* call the <a>DescribeAccountLimits</a> API. For information about updating
* this limit, see <a href="https://docs.aws.amazon.com/autoscaling/ec2/userguide/as-account-limits.html">Amazon EC2 Auto Scaling service
* quotas</a> in the <i>Amazon EC2 Auto Scaling User Guide</i>.</p>
* <p>For introductory exercises for creating an Auto Scaling group, see <a href="https://docs.aws.amazon.com/autoscaling/ec2/userguide/GettingStartedTutorial.html">Getting started with
* Amazon EC2 Auto Scaling</a> and <a href="https://docs.aws.amazon.com/autoscaling/ec2/userguide/as-register-lbs-with-asg.html">Tutorial: Set up a
* scaled and load-balanced application</a> in the
* <i>Amazon EC2 Auto Scaling User Guide</i>. For more information, see <a href="https://docs.aws.amazon.com/autoscaling/ec2/userguide/AutoScalingGroup.html">Auto Scaling
* groups</a> in the <i>Amazon EC2 Auto Scaling User Guide</i>.</p>
* <p>Every Auto Scaling group has three size parameters (<code>DesiredCapacity</code>,
* <code>MaxSize</code>, and <code>MinSize</code>). Usually, you set these sizes based
* on a specific number of instances. However, if you configure a mixed instances policy
* that defines weights for the instance types, you must specify these sizes with the same
* units that you use for weighting instances.</p>
* @example
* Use a bare-bones client and the command you need to make an API call.
* ```javascript
* import { AutoScalingClient, CreateAutoScalingGroupCommand } from "@aws-sdk/client-auto-scaling"; // ES Modules import
* // const { AutoScalingClient, CreateAutoScalingGroupCommand } = require("@aws-sdk/client-auto-scaling"); // CommonJS import
* const client = new AutoScalingClient(config);
* const command = new CreateAutoScalingGroupCommand(input);
* const response = await client.send(command);
* ```
*
* @see {@link CreateAutoScalingGroupCommandInput} for command's `input` shape.
* @see {@link CreateAutoScalingGroupCommandOutput} for command's `response` shape.
* @see {@link AutoScalingClientResolvedConfig | config} for AutoScalingClient's `config` shape.
*
*/
export class CreateAutoScalingGroupCommand extends $Command<
CreateAutoScalingGroupCommandInput,
CreateAutoScalingGroupCommandOutput,
AutoScalingClientResolvedConfig
> {
// Start section: command_properties
// End section: command_properties
constructor(readonly input: CreateAutoScalingGroupCommandInput) {
// Start section: command_constructor
super();
// End section: command_constructor
}
/**
* @internal
*/
resolveMiddleware(
clientStack: MiddlewareStack<ServiceInputTypes, ServiceOutputTypes>,
configuration: AutoScalingClientResolvedConfig,
options?: __HttpHandlerOptions
): Handler<CreateAutoScalingGroupCommandInput, CreateAutoScalingGroupCommandOutput> {
this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize));
const stack = clientStack.concat(this.middlewareStack);
const { logger } = configuration;
const clientName = "AutoScalingClient";
const commandName = "CreateAutoScalingGroupCommand";
const handlerExecutionContext: HandlerExecutionContext = {
logger,
clientName,
commandName,
inputFilterSensitiveLog: CreateAutoScalingGroupType.filterSensitiveLog,
outputFilterSensitiveLog: (output: any) => output,
};
const { requestHandler } = configuration;
return stack.resolve(
(request: FinalizeHandlerArguments<any>) =>
requestHandler.handle(request.request as __HttpRequest, options || {}),
handlerExecutionContext
);
}
private serialize(input: CreateAutoScalingGroupCommandInput, context: __SerdeContext): Promise<__HttpRequest> {
return serializeAws_queryCreateAutoScalingGroupCommand(input, context);
}
private deserialize(output: __HttpResponse, context: __SerdeContext): Promise<CreateAutoScalingGroupCommandOutput> {
return deserializeAws_queryCreateAutoScalingGroupCommand(output, context);
}
// Start section: command_body_extra
// End section: command_body_extra
}