LogFileIterator
extends IteratorIterator
in package
The `Aws\CloudTrail\LogFileIterator` provides an easy way to iterate over log file generated by AWS CloudTrail.
CloudTrail log files contain data about your AWS API calls and are stored in Amazon S3 at a predictable path based on a bucket name, a key prefix, an account ID, a region, and date information. This class allows you to specify options, including a date range, and emits each log file that match the provided options.
Yields an array containing the Amazon S3 bucket and key of the log file.
Table of Contents
Constants
- ACCOUNT_ID = 'account_id'
- DEFAULT_TRAIL_NAME = 'Default'
- END_DATE = 'end_date'
- KEY_PREFIX = 'key_prefix'
- LOG_REGION = 'log_region'
- PREFIX_TEMPLATE = 'prefix/AWSLogs/account/CloudTrail/region/date/'
- PREFIX_WILDCARD = '*'
- START_DATE = 'start_date'
- TRAIL_NAME = 'trail_name'
Methods
- __construct() : mixed
- Constructs a LogFileIterator using the specified options:
- current() : array<string|int, mixed>|bool
- An override of the typical current behavior of \IteratorIterator to format the output such that the bucket and key are returned in an array
- forTrail() : LogRecordIterator
- Constructs a LogRecordIterator. This factory method is used if the name of the S3 bucket containing your logs is not known. This factory method uses a CloudTrail client and the trail name (or "Default") to find the information about the trail necessary for constructing the LogRecordIterator.
Constants
ACCOUNT_ID
public
mixed
ACCOUNT_ID
= 'account_id'
DEFAULT_TRAIL_NAME
public
mixed
DEFAULT_TRAIL_NAME
= 'Default'
END_DATE
public
mixed
END_DATE
= 'end_date'
KEY_PREFIX
public
mixed
KEY_PREFIX
= 'key_prefix'
LOG_REGION
public
mixed
LOG_REGION
= 'log_region'
PREFIX_TEMPLATE
public
mixed
PREFIX_TEMPLATE
= 'prefix/AWSLogs/account/CloudTrail/region/date/'
PREFIX_WILDCARD
public
mixed
PREFIX_WILDCARD
= '*'
START_DATE
public
mixed
START_DATE
= 'start_date'
TRAIL_NAME
public
mixed
TRAIL_NAME
= 'trail_name'
Methods
__construct()
Constructs a LogFileIterator using the specified options:
public
__construct(S3Client $s3Client, string $s3BucketName[, array<string|int, mixed> $options = [] ]) : mixed
- trail_name: The name of the trail that is generating our logs. If none is provided, then "Default" will be used, since that is the name of the trail created in the AWS Management Console.
- key_prefix: The S3 key prefix of your log files. This value will be
overwritten when using the
fromTrail()
method. However, if you are using the constructor, then this value will be used. - start_date: The timestamp of the beginning of date range of the log
records you want to read. You can pass this in as a
DateTime
object, integer (unix timestamp), or a string compatible withstrtotime()
. - end_date: The timestamp of the end of date range of the log records
you want to read. You can pass this in as a
DateTime
object, integer (unix timestamp), or a string compatible withstrtotime()
. - account_id: This is your AWS account ID, which is the 12-digit number found on the Account Identifiers section of the AWS Security Credentials page. See https://console.aws.amazon.com/iam/home?#security_credential
- log_region: Region of the services of the log records you want to read.
Parameters
- $s3Client : S3Client
- $s3BucketName : string
- $options : array<string|int, mixed> = []
current()
An override of the typical current behavior of \IteratorIterator to format the output such that the bucket and key are returned in an array
public
current() : array<string|int, mixed>|bool
Return values
array<string|int, mixed>|boolforTrail()
Constructs a LogRecordIterator. This factory method is used if the name of the S3 bucket containing your logs is not known. This factory method uses a CloudTrail client and the trail name (or "Default") to find the information about the trail necessary for constructing the LogRecordIterator.
public
static forTrail(S3Client $s3Client, CloudTrailClient $cloudTrailClient[, array<string|int, mixed> $options = [] ]) : LogRecordIterator
Parameters
- $s3Client : S3Client
- $cloudTrailClient : CloudTrailClient
- $options : array<string|int, mixed> = []