/AWS1/CL_IAM=>GETSERVICELASTACCESSEDDETS()
¶
About GetServiceLastAccessedDetails¶
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 Amazon Web Services services that the resource
(user, group, role, or managed policy) can access.
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, Organizations policies, IAM permissions boundaries, and STS assume role policies. It only applies permissions policy logic. For more about the evaluation of policy types, see Evaluating policies 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 in the IAM User Guide.
Method Signature¶
IMPORTING¶
Required arguments:¶
iv_jobid
TYPE /AWS1/IAMJOBIDTYPE
/AWS1/IAMJOBIDTYPE
¶
The ID of the request generated by the GenerateServiceLastAccessedDetails operation. The
JobId
returned byGenerateServiceLastAccessedDetail
must be used by the same role within a session, or by the same user when used to callGetServiceLastAccessedDetail
.
Optional arguments:¶
iv_maxitems
TYPE /AWS1/IAMMAXITEMSTYPE
/AWS1/IAMMAXITEMSTYPE
¶
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 istrue
.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 returnstrue
, andMarker
contains a value to include in the subsequent call that tells the service where to continue from.
iv_marker
TYPE /AWS1/IAMMARKERTYPE
/AWS1/IAMMARKERTYPE
¶
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.
RETURNING¶
oo_output
TYPE REF TO /aws1/cl_iamgetsvclastaccedd01
/AWS1/CL_IAMGETSVCLASTACCEDD01
¶
Domain /AWS1/RT_ACCOUNT_ID Primitive Type NUMC
Examples¶
Syntax Example¶
This is an example of the syntax for calling the method. It includes every possible argument and initializes every possible value. The data provided is not necessarily semantically accurate (for example the value "string" may be provided for something that is intended to be an instance ID, or in some cases two arguments may be mutually exclusive). The syntax shows the ABAP syntax for creating the various data structures.
DATA(lo_result) = lo_client->/aws1/if_iam~getservicelastaccesseddets(
iv_jobid = |string|
iv_marker = |string|
iv_maxitems = 123
).
This is an example of reading all possible response values
lo_result = lo_result.
IF lo_result IS NOT INITIAL.
lv_jobstatustype = lo_result->get_jobstatus( ).
lv_accessadvisorusagegranu = lo_result->get_jobtype( ).
lv_datetype = lo_result->get_jobcreationdate( ).
LOOP AT lo_result->get_serviceslastaccessed( ) into lo_row.
lo_row_1 = lo_row.
IF lo_row_1 IS NOT INITIAL.
lv_servicenametype = lo_row_1->get_servicename( ).
lv_datetype = lo_row_1->get_lastauthenticated( ).
lv_servicenamespacetype = lo_row_1->get_servicenamespace( ).
lv_arntype = lo_row_1->get_lastauthenticatedentity( ).
lv_stringtype = lo_row_1->get_lastauthenticatedregion( ).
lv_integertype = lo_row_1->get_totalauthntctdentities( ).
LOOP AT lo_row_1->get_trackedactslastaccessed( ) into lo_row_2.
lo_row_3 = lo_row_2.
IF lo_row_3 IS NOT INITIAL.
lv_stringtype = lo_row_3->get_actionname( ).
lv_arntype = lo_row_3->get_lastaccessedentity( ).
lv_datetype = lo_row_3->get_lastaccessedtime( ).
lv_stringtype = lo_row_3->get_lastaccessedregion( ).
ENDIF.
ENDLOOP.
ENDIF.
ENDLOOP.
lv_datetype = lo_result->get_jobcompletiondate( ).
lv_booleantype = lo_result->get_istruncated( ).
lv_responsemarkertype = lo_result->get_marker( ).
lo_errordetails = lo_result->get_error( ).
IF lo_errordetails IS NOT INITIAL.
lv_stringtype = lo_errordetails->get_message( ).
lv_stringtype = lo_errordetails->get_code( ).
ENDIF.
ENDIF.
To get details from a previously-generated report¶
The following operation gets details about the report with the job ID: examplef-1305-c245-eba4-71fe298bcda7
DATA(lo_result) = lo_client->/aws1/if_iam~getservicelastaccesseddets( iv_jobid = |examplef-1305-c245-eba4-71fe298bcda7| ) .