

# GetServiceLastAccessedDetails
<a name="API_GetServiceLastAccessedDetails"></a>

Retrieves a service last accessed report that was created using the `GenerateServiceLastAccessedDetails` operation. You can use the `JobId` parameter in `GetServiceLastAccessedDetails` to retrieve the status of your report job. When the report is complete, you can retrieve the generated report. The report includes a list of AWS services that the resource (user, group, role, or managed policy) can access.

**Note**  
Service last accessed data does not use other policy types when determining whether a resource could access a service. These other policy types include resource-based policies, access control lists, AWS Organizations policies, IAM permissions boundaries, and AWS STS assume role policies. It only applies permissions policy logic. For more about the evaluation of policy types, see [Evaluating policies](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_evaluation-logic.html#policy-eval-basics) in the *IAM User Guide*.

For each service that the resource could access using permissions policies, the operation returns details about the most recent access attempt. If there was no attempt, the service is listed without details about the most recent attempt to access the service. If the operation fails, the `GetServiceLastAccessedDetails` operation returns the reason that it failed.

The `GetServiceLastAccessedDetails` operation returns a list of services. This list includes the number of entities that have attempted to access the service and the date and time of the last attempt. It also returns the ARN of the following entity, depending on the resource ARN that you used to generate the report:
+  **User** – Returns the user ARN that you used to generate the report
+  **Group** – Returns the ARN of the group member (user) that last attempted to access the service
+  **Role** – Returns the role ARN that you used to generate the report
+  **Policy** – Returns the ARN of the user or role that last used the policy to attempt to access the service

By default, the list is sorted by service namespace.

If you specified `ACTION_LEVEL` granularity when you generated the report, this operation returns service and action last accessed data. This includes the most recent access attempt for each tracked action within a service. Otherwise, this operation returns only service data.

For more information about service and action last accessed data, see [Reducing permissions using service last accessed data](https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies_access-advisor.html) in the *IAM User Guide*.

## Request Parameters
<a name="API_GetServiceLastAccessedDetails_RequestParameters"></a>

 For information about the parameters that are common to all actions, see [Common Parameters](CommonParameters.md).

 ** JobId **   
The ID of the request generated by the [GenerateServiceLastAccessedDetails](https://docs.aws.amazon.com/IAM/latest/APIReference/API_GenerateServiceLastAccessedDetails.html) operation. The `JobId` returned by `GenerateServiceLastAccessedDetail` must be used by the same role within a session, or by the same user when used to call `GetServiceLastAccessedDetail`.  
Type: String  
Length Constraints: Fixed length of 36.  
Required: Yes

 ** 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.  
Type: String  
Length Constraints: Minimum length of 1.  
Pattern: `[\u0020-\u00FF]+`   
Required: No

 ** 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.  
Type: Integer  
Valid Range: Minimum value of 1. Maximum value of 1000.  
Required: No

## Response Elements
<a name="API_GetServiceLastAccessedDetails_ResponseElements"></a>

The following elements are returned by the service.

 ** Error **   
An object that contains details about the reason the operation failed.  
Type: [ErrorDetails](API_ErrorDetails.md) object

 ** IsTruncated **   
A flag that indicates whether there are more items to return. If your results were truncated, you can make a subsequent pagination request using the `Marker` request parameter to retrieve more items. Note that IAM might return fewer than the `MaxItems` number of results even when there are more results available. We recommend that you check `IsTruncated` after every call to ensure that you receive all your results.  
Type: Boolean

 ** JobCompletionDate **   
The date and time, in [ISO 8601 date-time format](http://www.iso.org/iso/iso8601), when the generated report job was completed or failed.  
This field is null if the job is still in progress, as indicated by a job status value of `IN_PROGRESS`.  
Type: Timestamp

 ** JobCreationDate **   
The date and time, in [ISO 8601 date-time format](http://www.iso.org/iso/iso8601), when the report job was created.  
Type: Timestamp

 ** JobStatus **   
The status of the job.  
Type: String  
Valid Values: `IN_PROGRESS | COMPLETED | FAILED` 

 ** JobType **   
The type of job. Service jobs return information about when each service was last accessed. Action jobs also include information about when tracked actions within the service were last accessed.  
Type: String  
Valid Values: `SERVICE_LEVEL | ACTION_LEVEL` 

 ** Marker **   
When `IsTruncated` is `true`, this element is present and contains the value to use for the `Marker` parameter in a subsequent pagination request.  
Type: String

 **ServicesLastAccessed.member.N**   
 A `ServiceLastAccessed` object that contains details about the most recent attempt to access the service.  
Type: Array of [ServiceLastAccessed](API_ServiceLastAccessed.md) objects

## Errors
<a name="API_GetServiceLastAccessedDetails_Errors"></a>

For information about the errors that are common to all actions, see [Common Error Types](CommonErrors.md).

 ** InvalidInput **   
The request was rejected because an invalid or out-of-range value was supplied for an input parameter.  
HTTP Status Code: 400

 ** NoSuchEntity **   
The request was rejected because it referenced a resource entity that does not exist. The error message describes the resource.  
HTTP Status Code: 404

## Examples
<a name="API_GetServiceLastAccessedDetails_Examples"></a>

### Example
<a name="API_GetServiceLastAccessedDetails_Example_1"></a>

This example illustrates one usage of GetServiceLastAccessedDetails.

#### Sample Request
<a name="API_GetServiceLastAccessedDetails_Example_1_Request"></a>

```
https://iam.amazonaws.com/?Action=GetServiceLastAccessedDetails
&JobId=examplef-1305-c245-eba4-71fe298bcda7
&Version=2010-05-08
&AUTHPARAMS
```

#### Sample Response
<a name="API_GetServiceLastAccessedDetails_Example_1_Response"></a>

```
<IsTruncated>false</IsTruncated>
<JobCompletionDate>2018-10-24T19:47:35.241Z</JobCompletionDate>
<JobCreationDate>2018-10-24T19:47:31.466Z</JobCreationDate>
<JobStatus>COMPLETED</JobStatus>
<ServicesLastAccessed>
    <member>
        <ServiceName>AWS Identity and Access Management</ServiceName>
        <ServiceNamespace>iam</ServiceNamespace>
        <TotalAuthenticatedEntities>0</TotalAuthenticatedEntities>
    </member>
    <member>
        <LastAuthenticated>2018-10-24T19:11:00Z</LastAuthenticated>
        <LastAuthenticatedEntity>arn:aws:iam::123456789012:user/AWSExampleUser01</LastAuthenticatedEntity>
        <LastAuthenticatedRegion>us-east-1</LastAuthenticatedRegion>
        <ServiceName>Amazon Simple Storage Service</ServiceName>
        <ServiceNamespace>s3</ServiceNamespace>
        <TotalAuthenticatedEntities>3</TotalAuthenticatedEntities>
        <TrackedActionsLastAccessed>
            <member>
                <ActionName>CreateBucket</ActionName>
                <LastAccessedEntity>arn:aws:iam::123456789012:user/AWSExampleUser01</LastAccessedEntity>
                <LastAccessedRegion>us-east-1</LastAccessedRegion>
                <LastAccessedTime>2018-10-24T19:11:00Z</LastAccessedTime>
            </member>
            <member>
                <ActionName>PutBucketAcl</ActionName>
                <LastAccessedEntity></LastAccessedEntity>
                <LastAccessedRegion></LastAccessedRegion>
                <LastAccessedTime></LastAccessedTime>
            </member>
            <member>
                <ActionName>ListBucket</ActionName>
                <LastAccessedEntity>arn:aws:iam::123456789012:user/AWSExampleUser01</LastAccessedEntity>
                <LastAccessedRegion>us-east-1</LastAccessedRegion>
                <LastAccessedTime>2018-10-24T19:10:53Z</LastAccessedTime>
            </member>
        </TrackedActionsLastAccessed>
    </member>
</ServicesLastAccessed>
```

## See Also
<a name="API_GetServiceLastAccessedDetails_SeeAlso"></a>

For more information about using this API in one of the language-specific AWS SDKs, see the following:
+  [AWS Command Line Interface V2](https://docs.aws.amazon.com/goto/cli2/iam-2010-05-08/GetServiceLastAccessedDetails) 
+  [AWS SDK for .NET V4](https://docs.aws.amazon.com/goto/DotNetSDKV4/iam-2010-05-08/GetServiceLastAccessedDetails) 
+  [AWS SDK for C\$1\$1](https://docs.aws.amazon.com/goto/SdkForCpp/iam-2010-05-08/GetServiceLastAccessedDetails) 
+  [AWS SDK for Go v2](https://docs.aws.amazon.com/goto/SdkForGoV2/iam-2010-05-08/GetServiceLastAccessedDetails) 
+  [AWS SDK for Java V2](https://docs.aws.amazon.com/goto/SdkForJavaV2/iam-2010-05-08/GetServiceLastAccessedDetails) 
+  [AWS SDK for JavaScript V3](https://docs.aws.amazon.com/goto/SdkForJavaScriptV3/iam-2010-05-08/GetServiceLastAccessedDetails) 
+  [AWS SDK for Kotlin](https://docs.aws.amazon.com/goto/SdkForKotlin/iam-2010-05-08/GetServiceLastAccessedDetails) 
+  [AWS SDK for PHP V3](https://docs.aws.amazon.com/goto/SdkForPHPV3/iam-2010-05-08/GetServiceLastAccessedDetails) 
+  [AWS SDK for Python](https://docs.aws.amazon.com/goto/boto3/iam-2010-05-08/GetServiceLastAccessedDetails) 
+  [AWS SDK for Ruby V3](https://docs.aws.amazon.com/goto/SdkForRubyV3/iam-2010-05-08/GetServiceLastAccessedDetails) 