Skip to main content

protection_groups

Creates, updates, deletes or gets a protection_group resource or lists protection_groups in a region

Overview

Nameprotection_groups
TypeResource
DescriptionA grouping of protected resources so they can be handled as a collective. This resource grouping improves the accuracy of detection and reduces false positives.
Idawscc.shield.protection_groups

Fields

NameDatatypeDescription
protection_group_idstringThe 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.
protection_group_arnstringThe ARN (Amazon Resource Name) of the protection group.
aggregationstring
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 Amazon CloudFront and origin resources for CloudFront distributions.
patternstringThe 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.
membersarrayThe 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.
resource_typestringThe 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.
tagsarrayOne or more tag key-value pairs for the Protection object.
regionstringAWS region.

For more information, see AWS::Shield::ProtectionGroup.

Methods

NameResourceAccessible byRequired Params
create_resourceprotection_groupsINSERTAggregation, Pattern, ProtectionGroupId, region
delete_resourceprotection_groupsDELETEIdentifier, region
update_resourceprotection_groupsUPDATEIdentifier, PatchDocument, region
list_resourcesprotection_groups_list_onlySELECTregion
get_resourceprotection_groupsSELECTIdentifier, region

SELECT examples

Gets all properties from an individual protection_group.

SELECT
region,
protection_group_id,
protection_group_arn,
aggregation,
pattern,
members,
resource_type,
tags
FROM awscc.shield.protection_groups
WHERE
region = 'us-east-1' AND
Identifier = '{{ protection_group_arn }}';

INSERT example

Use the following StackQL query and manifest file to create a new protection_group resource, using stack-deploy.

/*+ create */
INSERT INTO awscc.shield.protection_groups (
ProtectionGroupId,
Aggregation,
Pattern,
region
)
SELECT
'{{ protection_group_id }}',
'{{ aggregation }}',
'{{ pattern }}',
'{{ region }}'
RETURNING
ErrorCode,
EventTime,
Identifier,
Operation,
OperationStatus,
RequestToken,
ResourceModel,
RetryAfter,
StatusMessage,
TypeName
;

UPDATE example

Use the following StackQL query and manifest file to update a protection_group resource, using stack-deploy.

/*+ update */
UPDATE awscc.shield.protection_groups
SET PatchDocument = string('{{ {
"Aggregation": aggregation,
"Pattern": pattern,
"Members": members,
"ResourceType": resource_type,
"Tags": tags
} | generate_patch_document }}')
WHERE
region = '{{ region }}' AND
Identifier = '{{ protection_group_arn }}'
RETURNING
ErrorCode,
EventTime,
Identifier,
Operation,
OperationStatus,
RequestToken,
ResourceModel,
RetryAfter,
StatusMessage,
TypeName
;

DELETE example

/*+ delete */
DELETE FROM awscc.shield.protection_groups
WHERE
Identifier = '{{ protection_group_arn }}' AND
region = 'us-east-1'
RETURNING
ErrorCode,
EventTime,
Identifier,
Operation,
OperationStatus,
RequestToken,
ResourceModel,
RetryAfter,
StatusMessage,
TypeName
;

Additional Parameters

Mutable resources in the Cloud Control provider support additional optional parameters which can be supplied with INSERT, UPDATE, or DELETE operations. These include:

ParameterDescription
ClientToken
A unique identifier to ensure the idempotency of the resource request.This allows the provider to accurately distinguish between retries and new requests.
A client token is valid for 36 hours once used.
After that, a resource request with the same client token is treated as a new request.
If you do not specify a client token, one is generated for inclusion in the request.
RoleArn
The ARN of the IAM role used to perform this resource operation.The role specified must have the permissions required for this operation.
If you do not specify a role, a temporary session is created using your AWS user credentials.
TypeVersionId
For private resource types, the type version to use in this resource operation.If you do not specify a resource version, the default version is used.

Permissions

To operate on the protection_groups resource, the following permissions are required:

shield:CreateProtectionGroup,
shield:TagResource