// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
impl super::Client {
/// Constructs a fluent builder for the [`CreateSecurityGroup`](crate::operation::create_security_group::builders::CreateSecurityGroupFluentBuilder) operation.
///
/// - The fluent builder is configurable:
/// - [`description(impl ::std::convert::Into<String>)`](crate::operation::create_security_group::builders::CreateSecurityGroupFluentBuilder::description) / [`set_description(Option<String>)`](crate::operation::create_security_group::builders::CreateSecurityGroupFluentBuilder::set_description): <p>A description for the security group.</p> <p>Constraints: Up to 255 characters in length</p> <p>Valid characters: a-z, A-Z, 0-9, spaces, and ._-:/()#,@[]+=&;{}!$*</p>
/// - [`group_name(impl ::std::convert::Into<String>)`](crate::operation::create_security_group::builders::CreateSecurityGroupFluentBuilder::group_name) / [`set_group_name(Option<String>)`](crate::operation::create_security_group::builders::CreateSecurityGroupFluentBuilder::set_group_name): <p>The name of the security group.</p> <p>Constraints: Up to 255 characters in length. Cannot start with <code>sg-</code>.</p> <p>Valid characters: a-z, A-Z, 0-9, spaces, and ._-:/()#,@[]+=&;{}!$*</p>
/// - [`vpc_id(impl ::std::convert::Into<String>)`](crate::operation::create_security_group::builders::CreateSecurityGroupFluentBuilder::vpc_id) / [`set_vpc_id(Option<String>)`](crate::operation::create_security_group::builders::CreateSecurityGroupFluentBuilder::set_vpc_id): <p>The ID of the VPC. Required for a nondefault VPC.</p>
/// - [`tag_specifications(Vec<TagSpecification>)`](crate::operation::create_security_group::builders::CreateSecurityGroupFluentBuilder::tag_specifications) / [`set_tag_specifications(Option<Vec<TagSpecification>>)`](crate::operation::create_security_group::builders::CreateSecurityGroupFluentBuilder::set_tag_specifications): <p>The tags to assign to the security group.</p>
/// - [`dry_run(bool)`](crate::operation::create_security_group::builders::CreateSecurityGroupFluentBuilder::dry_run) / [`set_dry_run(Option<bool>)`](crate::operation::create_security_group::builders::CreateSecurityGroupFluentBuilder::set_dry_run): <p>Checks whether you have the required permissions for the action, without actually making the request, and provides an error response. If you have the required permissions, the error response is <code>DryRunOperation</code>. Otherwise, it is <code>UnauthorizedOperation</code>.</p>
/// - On success, responds with [`CreateSecurityGroupOutput`](crate::operation::create_security_group::CreateSecurityGroupOutput) with field(s):
/// - [`group_id(Option<String>)`](crate::operation::create_security_group::CreateSecurityGroupOutput::group_id): <p>The ID of the security group.</p>
/// - [`tags(Option<Vec<Tag>>)`](crate::operation::create_security_group::CreateSecurityGroupOutput::tags): <p>The tags assigned to the security group.</p>
/// - On failure, responds with [`SdkError<CreateSecurityGroupError>`](crate::operation::create_security_group::CreateSecurityGroupError)
pub fn create_security_group(&self) -> crate::operation::create_security_group::builders::CreateSecurityGroupFluentBuilder {
crate::operation::create_security_group::builders::CreateSecurityGroupFluentBuilder::new(self.handle.clone())
}
}