createWebACLMigrationStack method
Creates an AWS CloudFormation WAFV2 template for the specified web ACL in the specified Amazon S3 bucket. Then, in CloudFormation, you create a stack from the template, to create the web ACL and its resources in AWS WAFV2. Use this to migrate your AWS WAF Classic web ACL to the latest version of AWS WAF.
This is part of a larger migration procedure for web ACLs from AWS WAF Classic to the latest version of AWS WAF. For the full procedure, including caveats and manual steps to complete the migration and switch over to the new web ACL, see Migrating your AWS WAF Classic resources to AWS WAF in the AWS WAF Developer Guide.
May throw WAFInternalErrorException. May throw WAFInvalidParameterException. May throw WAFInvalidOperationException. May throw WAFNonexistentItemException. May throw WAFEntityMigrationException.
Parameter ignoreUnsupportedType
:
Indicates whether to exclude entities that can't be migrated or to stop
the migration. Set this to true to ignore unsupported entities in the web
ACL during the migration. Otherwise, if AWS WAF encounters unsupported
entities, it stops the process and throws an exception.
Parameter s3BucketName
:
The name of the Amazon S3 bucket to store the CloudFormation template in.
The S3 bucket must be configured as follows for the migration:
-
The bucket name must start with
aws-waf-migration-
. For example,aws-waf-migration-my-web-acl
. - The bucket must be in the Region where you are deploying the template. For example, for a web ACL in us-west-2, you must use an Amazon S3 bucket in us-west-2 and you must deploy the template stack to us-west-2.
- The bucket policies must permit the migration process to write data. For listings of the bucket policies, see the Examples section.
Parameter webACLId
:
The UUID of the WAF Classic web ACL that you want to migrate to WAF v2.
Implementation
Future<CreateWebACLMigrationStackResponse> createWebACLMigrationStack({
required bool ignoreUnsupportedType,
required String s3BucketName,
required String webACLId,
}) async {
ArgumentError.checkNotNull(ignoreUnsupportedType, 'ignoreUnsupportedType');
ArgumentError.checkNotNull(s3BucketName, 's3BucketName');
_s.validateStringLength(
's3BucketName',
s3BucketName,
3,
63,
isRequired: true,
);
ArgumentError.checkNotNull(webACLId, 'webACLId');
_s.validateStringLength(
'webACLId',
webACLId,
1,
128,
isRequired: true,
);
final headers = <String, String>{
'Content-Type': 'application/x-amz-json-1.1',
'X-Amz-Target': 'AWSWAF_20150824.CreateWebACLMigrationStack'
};
final jsonResponse = await _protocol.send(
method: 'POST',
requestUri: '/',
exceptionFnMap: _exceptionFns,
// TODO queryParams
headers: headers,
payload: {
'IgnoreUnsupportedType': ignoreUnsupportedType,
'S3BucketName': s3BucketName,
'WebACLId': webACLId,
},
);
return CreateWebACLMigrationStackResponse.fromJson(jsonResponse.body);
}