The London Perl and Raku Workshop takes place on 26th Oct 2024. If your company depends on Perl, please consider sponsoring and/or attending.

NAME

Paws::Shield::CreateProtectionGroup - Arguments for method CreateProtectionGroup on Paws::Shield

DESCRIPTION

This class represents the parameters used for calling the method CreateProtectionGroup on the AWS Shield service. Use the attributes of this class as arguments to method CreateProtectionGroup.

You shouldn't make instances of this class. Each attribute should be used as a named argument in the call to CreateProtectionGroup.

SYNOPSIS

    my $shield = Paws->service('Shield');
    my $CreateProtectionGroupResponse = $shield->CreateProtectionGroup(
      Aggregation       => 'SUM',
      Pattern           => 'ALL',
      ProtectionGroupId => 'MyProtectionGroupId',
      Members           => [
        'MyResourceArn', ...    # min: 1, max: 2048
      ],    # OPTIONAL
      ResourceType => 'CLOUDFRONT_DISTRIBUTION',    # OPTIONAL
      Tags         => [
        {
          Key   => 'MyTagKey',      # min: 1, max: 128; OPTIONAL
          Value => 'MyTagValue',    # max: 256; OPTIONAL
        },
        ...
      ],    # OPTIONAL
    );

Values for attributes that are native types (Int, String, Float, etc) can passed as-is (scalar values). Values for complex Types (objects) can be passed as a HashRef. The keys and values of the hashref will be used to instance the underlying object. For the AWS API documentation, see https://docs.aws.amazon.com/goto/WebAPI/shield/CreateProtectionGroup

ATTRIBUTES

REQUIRED Aggregation => Str

Defines how AWS Shield combines resource data for the group in order to detect, mitigate, and report events.

  • Sum - Use the total traffic across the group. This is a good choice for most cases. Examples include Elastic IP addresses for EC2 instances that scale manually or automatically.

  • Mean - Use the average of the traffic across the group. This is a good choice for resources that share traffic uniformly. Examples include accelerators and load balancers.

  • Max - Use the highest traffic from each resource. This is useful for resources that don't share traffic and for resources that share that traffic in a non-uniform way. Examples include CloudFront distributions and origin resources for CloudFront distributions.

Valid values are: "SUM", "MEAN", "MAX"

Members => ArrayRef[Str|Undef]

The Amazon Resource Names (ARNs) of the resources to include in the protection group. You must set this when you set Pattern to ARBITRARY and you must not set it for any other Pattern setting.

REQUIRED Pattern => Str

The criteria to use to choose the protected resources for inclusion in the group. You can include all resources that have protections, provide a list of resource Amazon Resource Names (ARNs), or include all resources of a specified resource type.

Valid values are: "ALL", "ARBITRARY", "BY_RESOURCE_TYPE"

REQUIRED ProtectionGroupId => Str

The name of the protection group. You use this to identify the protection group in lists and to manage the protection group, for example to update, delete, or describe it.

ResourceType => Str

The resource type to include in the protection group. All protected resources of this type are included in the protection group. Newly protected resources of this type are automatically added to the group. You must set this when you set Pattern to BY_RESOURCE_TYPE and you must not set it for any other Pattern setting.

Valid values are: "CLOUDFRONT_DISTRIBUTION", "ROUTE_53_HOSTED_ZONE", "ELASTIC_IP_ALLOCATION", "CLASSIC_LOAD_BALANCER", "APPLICATION_LOAD_BALANCER", "GLOBAL_ACCELERATOR"

Tags => ArrayRef[Paws::Shield::Tag]

One or more tag key-value pairs for the protection group.

SEE ALSO

This class forms part of Paws, documenting arguments for method CreateProtectionGroup in Paws::Shield

BUGS and CONTRIBUTIONS

The source code is located here: https://github.com/pplu/aws-sdk-perl

Please report bugs to: https://github.com/pplu/aws-sdk-perl/issues