AWS CloudTrail

2018/10/12 - AWS CloudTrail - 1 updated api methods

Changes  The LookupEvents API now supports two new attribute keys: ReadOnly and AccessKeyId

LookupEvents (updated) Link ΒΆ
Changes (request, response)
Request
{'LookupAttributes': {'AttributeKey': {'AccessKeyId', 'ReadOnly'}}}
Response
{'Events': {'AccessKeyId': 'string', 'ReadOnly': 'string'}}

Looks up management events captured by CloudTrail. Events for a region can be looked up in that region during the last 90 days. Lookup supports the following attributes:

  • AWS access key

  • Event ID

  • Event name

  • Event source

  • Read only

  • Resource name

  • Resource type

  • User name

All attributes are optional. The default number of results returned is 50, with a maximum of 50 possible. The response includes a token that you can use to get the next page of results.

Warning

The rate of lookup requests is limited to one per second per account. If this limit is exceeded, a throttling error occurs.

Warning

Events that occurred during the selected time range will not be available for lookup if CloudTrail logging was not enabled when the events occurred.

See also: AWS API Documentation

Request Syntax

client.lookup_events(
    LookupAttributes=[
        {
            'AttributeKey': 'EventId'|'EventName'|'ReadOnly'|'Username'|'ResourceType'|'ResourceName'|'EventSource'|'AccessKeyId',
            'AttributeValue': 'string'
        },
    ],
    StartTime=datetime(2015, 1, 1),
    EndTime=datetime(2015, 1, 1),
    MaxResults=123,
    NextToken='string'
)
type LookupAttributes

list

param LookupAttributes

Contains a list of lookup attributes. Currently the list can contain only one item.

  • (dict) --

    Specifies an attribute and value that filter the events returned.

    • AttributeKey (string) -- [REQUIRED]

      Specifies an attribute on which to filter the events returned.

    • AttributeValue (string) -- [REQUIRED]

      Specifies a value for the specified AttributeKey.

type StartTime

datetime

param StartTime

Specifies that only events that occur after or at the specified time are returned. If the specified start time is after the specified end time, an error is returned.

type EndTime

datetime

param EndTime

Specifies that only events that occur before or at the specified time are returned. If the specified end time is before the specified start time, an error is returned.

type MaxResults

integer

param MaxResults

The number of events to return. Possible values are 1 through 50. The default is 50.

type NextToken

string

param NextToken

The token to use to get the next page of results after a previous API call. This token must be passed in with the same parameters that were specified in the the original call. For example, if the original call specified an AttributeKey of 'Username' with a value of 'root', the call with NextToken should include those same parameters.

rtype

dict

returns

Response Syntax

{
    'Events': [
        {
            'EventId': 'string',
            'EventName': 'string',
            'ReadOnly': 'string',
            'AccessKeyId': 'string',
            'EventTime': datetime(2015, 1, 1),
            'EventSource': 'string',
            'Username': 'string',
            'Resources': [
                {
                    'ResourceType': 'string',
                    'ResourceName': 'string'
                },
            ],
            'CloudTrailEvent': 'string'
        },
    ],
    'NextToken': 'string'
}

Response Structure

  • (dict) --

    Contains a response to a LookupEvents action.

    • Events (list) --

      A list of events returned based on the lookup attributes specified and the CloudTrail event. The events list is sorted by time. The most recent event is listed first.

      • (dict) --

        Contains information about an event that was returned by a lookup request. The result includes a representation of a CloudTrail event.

        • EventId (string) --

          The CloudTrail ID of the event returned.

        • EventName (string) --

          The name of the event returned.

        • ReadOnly (string) --

          Information about whether the event is a write event or a read event.

        • AccessKeyId (string) --

          The AWS access key ID that was used to sign the request. If the request was made with temporary security credentials, this is the access key ID of the temporary credentials.

        • EventTime (datetime) --

          The date and time of the event returned.

        • EventSource (string) --

          The AWS service that the request was made to.

        • Username (string) --

          A user name or role name of the requester that called the API in the event returned.

        • Resources (list) --

          A list of resources referenced by the event returned.

          • (dict) --

            Specifies the type and name of a resource referenced by an event.

            • ResourceType (string) --

              The type of a resource referenced by the event returned. When the resource type cannot be determined, null is returned. Some examples of resource types are: Instance for EC2, Trail for CloudTrail, DBInstance for RDS, and AccessKey for IAM. For a list of resource types supported for event lookup, see Resource Types Supported for Event Lookup.

            • ResourceName (string) --

              The name of the resource referenced by the event returned. These are user-created names whose values will depend on the environment. For example, the resource name might be "auto-scaling-test-group" for an Auto Scaling Group or "i-1234567" for an EC2 Instance.

        • CloudTrailEvent (string) --

          A JSON string that contains a representation of the event returned.

    • NextToken (string) --

      The token to use to get the next page of results after a previous API call. If the token does not appear, there are no more results to return. The token must be passed in with the same parameters as the previous call. For example, if the original call specified an AttributeKey of 'Username' with a value of 'root', the call with NextToken should include those same parameters.