detectStackDrift method

Future<DetectStackDriftOutput> detectStackDrift({
  1. required String stackName,
  2. List<String>? logicalResourceIds,
})

Detects whether a stack's actual configuration differs, or has drifted, from it's expected configuration, as defined in the stack template and any values specified as template parameters. For each resource in the stack that supports drift detection, AWS CloudFormation compares the actual configuration of the resource with its expected template configuration. Only resource properties explicitly defined in the stack template are checked for drift. A stack is considered to have drifted if one or more of its resources differ from their expected template configurations. For more information, see Detecting Unregulated Configuration Changes to Stacks and Resources.

Use DetectStackDrift to detect drift on all supported resources for a given stack, or DetectStackResourceDrift to detect drift on individual resources.

For a list of stack resources that currently support drift detection, see Resources that Support Drift Detection.

DetectStackDrift can take up to several minutes, depending on the number of resources contained within the stack. Use DescribeStackDriftDetectionStatus to monitor the progress of a detect stack drift operation. Once the drift detection operation has completed, use DescribeStackResourceDrifts to return drift information about the stack and its resources.

When detecting drift on a stack, AWS CloudFormation does not detect drift on any nested stacks belonging to that stack. Perform DetectStackDrift directly on the nested stack itself.

Parameter stackName : The name of the stack for which you want to detect drift.

Parameter logicalResourceIds : The logical names of any resources you want to use as filters.

Implementation

Future<DetectStackDriftOutput> detectStackDrift({
  required String stackName,
  List<String>? logicalResourceIds,
}) async {
  ArgumentError.checkNotNull(stackName, 'stackName');
  _s.validateStringLength(
    'stackName',
    stackName,
    1,
    1152921504606846976,
    isRequired: true,
  );
  final $request = <String, dynamic>{};
  $request['StackName'] = stackName;
  logicalResourceIds?.also((arg) => $request['LogicalResourceIds'] = arg);
  final $result = await _protocol.send(
    $request,
    action: 'DetectStackDrift',
    version: '2010-05-15',
    method: 'POST',
    requestUri: '/',
    exceptionFnMap: _exceptionFns,
    shape: shapes['DetectStackDriftInput'],
    shapes: shapes,
    resultWrapper: 'DetectStackDriftResult',
  );
  return DetectStackDriftOutput.fromXml($result);
}