Class CfnProtectionGroupProps.Builder

java.lang.Object
software.amazon.awscdk.services.shield.CfnProtectionGroupProps.Builder
All Implemented Interfaces:
software.amazon.jsii.Builder<CfnProtectionGroupProps>
Enclosing interface:
CfnProtectionGroupProps

@Stability(Stable) public static final class CfnProtectionGroupProps.Builder extends Object implements software.amazon.jsii.Builder<CfnProtectionGroupProps>
  • Constructor Details

    • Builder

      public Builder()
  • Method Details

    • aggregation

      @Stability(Stable) public CfnProtectionGroupProps.Builder aggregation(String aggregation)
      Parameters:
      aggregation - Defines how AWS Shield combines resource data for the group in order to detect, mitigate, and report events. This parameter is required.
      • 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 Amazon CloudFront distributions and origin resources for CloudFront distributions.
      Returns:
      this
    • pattern

      @Stability(Stable) public CfnProtectionGroupProps.Builder pattern(String pattern)
      Parameters:
      pattern - The criteria to use to choose the protected resources for inclusion in the group. This parameter is required. You can include all resources that have protections, provide a list of resource ARNs (Amazon Resource Names), or include all resources of a specified resource type.
      Returns:
      this
    • protectionGroupId

      @Stability(Stable) public CfnProtectionGroupProps.Builder protectionGroupId(String protectionGroupId)
      Parameters:
      protectionGroupId - The name of the protection group. This parameter is required. You use this to identify the protection group in lists and to manage the protection group, for example to update, delete, or describe it.
      Returns:
      this
    • members

      @Stability(Stable) public CfnProtectionGroupProps.Builder members(List<String> members)
      Parameters:
      members - The ARNs (Amazon Resource Names) 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.
      Returns:
      this
    • resourceType

      @Stability(Stable) public CfnProtectionGroupProps.Builder resourceType(String resourceType)
      Parameters:
      resourceType - The resource type to include in the protection group. All protected resources of this type are included in the protection group. You must set this when you set Pattern to BY_RESOURCE_TYPE and you must not set it for any other Pattern setting.
      Returns:
      this
    • tags

      @Stability(Stable) public CfnProtectionGroupProps.Builder tags(List<? extends CfnTag> tags)
      Parameters:
      tags - Key:value pairs associated with an AWS resource. The key:value pair can be anything you define. Typically, the tag key represents a category (such as "environment") and the tag value represents a specific value within that category (such as "test," "development," or "production"). You can add up to 50 tags to each AWS resource.
      Returns:
      this
    • build

      @Stability(Stable) public CfnProtectionGroupProps build()
      Builds the configured instance.
      Specified by:
      build in interface software.amazon.jsii.Builder<CfnProtectionGroupProps>
      Returns:
      a new instance of CfnProtectionGroupProps
      Throws:
      NullPointerException - if any required attribute was not provided