getServiceLastAccessedDetailsWithEntities method

Future<GetServiceLastAccessedDetailsWithEntitiesResponse> getServiceLastAccessedDetailsWithEntities({
  1. required String jobId,
  2. required String serviceNamespace,
  3. String? marker,
  4. int? maxItems,
})

After you generate a group or policy report using the GenerateServiceLastAccessedDetails operation, you can use the JobId parameter in GetServiceLastAccessedDetailsWithEntities. This operation retrieves the status of your report job and a list of entities that could have used group or policy permissions to access the specified service.

  • Group – For a group report, this operation returns a list of users in the group that could have used the group’s policies in an attempt to access the service.
  • Policy – For a policy report, this operation returns a list of entities (users or roles) that could have used the policy in an attempt to access the service.
You can also use this operation for user or role reports to retrieve details about those entities.

If the operation fails, the GetServiceLastAccessedDetailsWithEntities operation returns the reason that it failed.

By default, the list of associated entities is sorted by date, with the most recent access listed first.

May throw NoSuchEntityException. May throw InvalidInputException.

Parameter jobId : The ID of the request generated by the GenerateServiceLastAccessedDetails operation.

Parameter serviceNamespace : The service namespace for an AWS service. Provide the service namespace to learn when the IAM entity last attempted to access the specified service.

To learn the service namespace for a service, go to Actions, Resources, and Condition Keys for AWS Services in the IAM User Guide. Choose the name of the service to view details for that service. In the first paragraph, find the service prefix. For example, (service prefix: a4b). For more information about service namespaces, see AWS Service Namespaces in the AWS General Reference.

Parameter marker : Use this parameter only when paginating results and only after you receive a response indicating that the results are truncated. Set it to the value of the Marker element in the response that you received to indicate where the next call should start.

Parameter maxItems : Use this only when paginating results to indicate the maximum number of items you want in the response. If additional items exist beyond the maximum you specify, the IsTruncated response element is true.

If you do not include this parameter, the number of items defaults to 100. Note that IAM might return fewer results, even when there are more results available. In that case, the IsTruncated response element returns true, and Marker contains a value to include in the subsequent call that tells the service where to continue from.

Implementation

Future<GetServiceLastAccessedDetailsWithEntitiesResponse>
    getServiceLastAccessedDetailsWithEntities({
  required String jobId,
  required String serviceNamespace,
  String? marker,
  int? maxItems,
}) async {
  ArgumentError.checkNotNull(jobId, 'jobId');
  _s.validateStringLength(
    'jobId',
    jobId,
    36,
    36,
    isRequired: true,
  );
  ArgumentError.checkNotNull(serviceNamespace, 'serviceNamespace');
  _s.validateStringLength(
    'serviceNamespace',
    serviceNamespace,
    1,
    64,
    isRequired: true,
  );
  _s.validateStringLength(
    'marker',
    marker,
    1,
    320,
  );
  _s.validateNumRange(
    'maxItems',
    maxItems,
    1,
    1000,
  );
  final $request = <String, dynamic>{};
  $request['JobId'] = jobId;
  $request['ServiceNamespace'] = serviceNamespace;
  marker?.also((arg) => $request['Marker'] = arg);
  maxItems?.also((arg) => $request['MaxItems'] = arg);
  final $result = await _protocol.send(
    $request,
    action: 'GetServiceLastAccessedDetailsWithEntities',
    version: '2010-05-08',
    method: 'POST',
    requestUri: '/',
    exceptionFnMap: _exceptionFns,
    shape: shapes['GetServiceLastAccessedDetailsWithEntitiesRequest'],
    shapes: shapes,
    resultWrapper: 'GetServiceLastAccessedDetailsWithEntitiesResult',
  );
  return GetServiceLastAccessedDetailsWithEntitiesResponse.fromXml($result);
}