describeAffectedEntitiesForOrganization method

Future<DescribeAffectedEntitiesForOrganizationResponse> describeAffectedEntitiesForOrganization({
  1. required List<EventAccountFilter> organizationEntityFilters,
  2. String? locale,
  3. int? maxResults,
  4. String? nextToken,
})

Returns a list of entities that have been affected by one or more events for one or more accounts in your organization in AWS Organizations, based on the filter criteria. Entities can refer to individual customer resources, groups of customer resources, or any other construct, depending on the AWS service.

At least one event Amazon Resource Name (ARN) and account ID are required. Results are sorted by the lastUpdatedTime of the entity, starting with the most recent.

Before you can call this operation, you must first enable AWS Health to work with AWS Organizations. To do this, call the EnableHealthServiceAccessForOrganization operation from your organization's master account.

May throw InvalidPaginationToken. May throw UnsupportedLocale.

Parameter organizationEntityFilters : A JSON set of elements including the awsAccountId and the eventArn.

Parameter locale : The locale (language) to return information in. English (en) is the default and the only supported value at this time.

Parameter maxResults : The maximum number of items to return in one batch, between 10 and 100, inclusive.

Parameter nextToken : If the results of a search are large, only a portion of the results are returned, and a nextToken pagination token is returned in the response. To retrieve the next batch of results, reissue the search request and include the returned token. When all results have been returned, the response does not contain a pagination token value.

Implementation

Future<DescribeAffectedEntitiesForOrganizationResponse>
    describeAffectedEntitiesForOrganization({
  required List<EventAccountFilter> organizationEntityFilters,
  String? locale,
  int? maxResults,
  String? nextToken,
}) async {
  ArgumentError.checkNotNull(
      organizationEntityFilters, 'organizationEntityFilters');
  _s.validateStringLength(
    'locale',
    locale,
    2,
    256,
  );
  _s.validateNumRange(
    'maxResults',
    maxResults,
    10,
    100,
  );
  _s.validateStringLength(
    'nextToken',
    nextToken,
    4,
    10000,
  );
  final headers = <String, String>{
    'Content-Type': 'application/x-amz-json-1.1',
    'X-Amz-Target':
        'AWSHealth_20160804.DescribeAffectedEntitiesForOrganization'
  };
  final jsonResponse = await _protocol.send(
    method: 'POST',
    requestUri: '/',
    exceptionFnMap: _exceptionFns,
    // TODO queryParams
    headers: headers,
    payload: {
      'organizationEntityFilters': organizationEntityFilters,
      if (locale != null) 'locale': locale,
      if (maxResults != null) 'maxResults': maxResults,
      if (nextToken != null) 'nextToken': nextToken,
    },
  );

  return DescribeAffectedEntitiesForOrganizationResponse.fromJson(
      jsonResponse.body);
}