getServiceLastAccessedDetailsWithEntities method
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.
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);
}