AWS CloudTrail
Overview
The procedures in this topic describe how to enable the collection of AWS CloudTrail logging in ActiveEye.
Prerequisites
Before you can set up the AWS CloudTrail service connector in ActiveEye, you must set up CloudTrail logging.
Customers have the option to set up CloudTrail logging on an account-by-account basis, or via the automated setup available when new accounts are created by AWS organizations. ActiveEye supports both methods.
For more information and to set up CloudTrail logging, refer to these AWS procedures:
To set up the service connectors in ActiveEye, you will need the AWS account ID for each AWS account that will be monitored by CloudTrail. To find the IDs, reference the following AWS procedure: Finding your AWS account ID.
Additionally, according to the AWS Well Architected Framework, it is best practice to use a centralized AWS logging account that is separate from the rest of the infrastructure as the owner of the logging S3 bucket. This allows permissions to be controlled, and promotes security. For ActiveEye, this is recommended but not required.
Creating a Service Connector for Each AWS Account
For each AWS account that will be monitored via CloudTrail, a corresponding service connector must be created in ActiveEye. This separates the data into distinctly monitored entities with differing priorities and statuses.
- In ActiveEye, in the left pane, click Admin, and then click Service Connectors.
The Service Connectors page appears.
- In the upper-left corner of the page, click Add Connector.
A list of service connectors appears.
- Scroll down to the CLOUD INFRASTRUCTURE section, and then, in the AWS Cloudtrail subsection, click the Add Connection button.
The Add Connector Account page appears. - In the Display Name box, enter a unique name.
- In the Account Number box, enter the 12-digit AWS account ID. See the Prerequisites section of this topic for information on how to find this ID.
- Optionally, modify the priority level in the Priority box. Raising or lowering the priority will increase or decrease the visibility of alerts related to this service connector.
- If you do not want data ingestion to begin immediately once cloud accounts have been configured, clear the Enable Account check box. Otherwise, leave the check box selected.
- Click Add.
The AWS CloudTrail service connector is created. - As needed, repeat these steps until an AWS CloudTrail service connector has been created for each AWS account that will be monitored.
Creating Connector Credentials for Each Service Connector
Next, you must set up an SNS notification to trigger when CloudTrail deposits a log in the S3 bucket. This is accomplished by setting up a connector credential in ActiveEye.
The credential does not need to be directly associated with the source AWS accounts. It is used for the assume role operation that is used to connect to and read from the bucket. This step needs to be performed only once per AWS account and bucket combination.
- In ActiveEye, in the left pane, click Admin, and then click Service Connectors.
The Service Connectors page appears.
- In the upper-right corner of the page, click Manage connectors credentials.
The Connector Credentials page appears.
- In the upper-left corner of the page, click Add Credential.
The Add Connector Credentials page appears. - In the Connector Type drop-down list box, click AWS CloudTrail.
The AWS Cloudtrail Bucket Configuration section appears. - In the Display Name box, enter a unique name.
- In the Bucket Name box, enter the name of the S3 bucket that is the Cloudtail log destination. The name that you enter must meet the following criteria:
- Must be between 3 and 63 characters long.
- Can consist only of lowercase letters, numbers, periods, and hyphens.
- Must begin and end with a letter or number.
- Must not be formatted as an IP address (for example, `192.168.5.4`).
- Must not start with the prefix `xn--`.
- Must not end with the suffix `-s3alias`.
- In the Bucket Account ID box, enter the 12-digit AWS account ID of the account that owns the S3 bucket that you referenced in the Bucket Name box.
- In the Bucket Region drop-down list box, select the AWS region in which the S3 bucket resides. For a comparison of region names and codes, reference this AWS topic: Available Regions.
- Click Add.
The AWS CloudTrail connector credentials are added, and the page is refreshed. - Record the read-only values in the SNS Notification ARN, Pod Account ID, and External ID boxes. You will need these values in subsequent procedures.
- As needed, repeat these steps for each AWS account that contains a bucket with CloudTrail logs that need to be monitored.
Creating CloudFormation Stack
After configuring a CloudTrail that is publishing to your own S3 bucket, the following steps will need to be performed by an AWS IAM user with permissions to create CloudFormation Stacks, CloudTrail Trails, and IAM Roles.
In this procedure, you will create a customer-managed policy named “activeeye-read-cloudtrail-policy” and a role that uses that policy named “activeeye-read-cloudtrail-role”. This role will have GetObject permissions on the S3 bucket of your choosing only.
This procedure will need to be performed for each AWS account that receives CloudTrail logs in an S3 bucket. For example, if your organization has three AWS accounts with CloudTrail that send logs to three S3 buckets in those same accounts, this step will need to be performed in each of those accounts. However, if your organization sends logs from the three accounts to a single AWS account that owns a single bucket, this procedure needs to be performed only once.
The CloudFormation template referenced below does not create a CloudTrail. It is assumed that, if you already have an S3 bucket configured to receive logging, you already have CloudTrail enabled.
- In the AWS console, in the upper-left corner of the screen, click Services.
- In the menu that appears, click Management & Governance, and then click CloudFormation.
The CloudFormation page appears. - Click the Create stack button, and then click With new resources.
The Create stack page appears.
- With the Amazon S3 URL check box selected, depending on your environment, enter the appropriate text in the Amazon S3 URL box:
- For a commercial environment, enter the following: `https://activeeye-cloudformation-templates.s3.amazonaws.com/activeeye-read-cloudtrail.yaml`
- For a government environment, enter the following: `https://activeeye-cloudformation-templates.s3-us-gov-west-1.amazonaws.com/activeeye-read-cloudtrail.yaml`
- Click Next.
The Specify stack details page appears.
- In the Stack name box, enter the following: `activeeye-cloudtrail-read`
- In the ActiveeyeAccountID box, enter the Pod Account ID that you recorded in the previous procedure.
- In the CloudtrailBucket box, enter the name of the S3 bucket receiving the log files (do not include a path, prefixes, or trailing forward slashes).
- In the ExternalID box, enter the External ID that you recorded in the previous procedure.
- Click Next.
The Configure stack options page appears. - Do not modify the default options. Click Next.
The Review page appears. - Select the I acknowledge that AWS CloudFormation might create IAM resources with custom names check box, and then click Submit.
The stack is created, and a page displaying information about it appears. - Repeat this procedure for each AWS account that contains a bucket with CloudTrail logs that needs to be monitored.
The External ID is not a secret in any way. It is simply an additional security measure that AWS recommends when allowing third parties to interact with your AWS resources. For more information on External IDs, reference this AWS blog post: How to Use External ID When Granting Access To your AWS Resources.
After you complete this procedure, when ActiveEye receives a notification to pull a file from a bucket, it will be able to associate the bucket with your customer account, and will have the permissions to read the file from the S3 bucket.
Enabling ActiveEye to Use the KMS Key
If a customer-managed KMS key is not used to encrypt the CloudTrail logs, you can skip to the Enable Notifications to ActiveEye procedure.
Recording the AWS KMS Key
If the AWS CloudTrail configuration utilizes customer-managed KMS keys for server-side encryption, the role and key policy must be edited to allow ActiveEye to decrypt the objects prior to reading the contents.
For situations where the target S3 bucket resides in a different account from the source Cloudtrail accounts, it is best practice to use the S3 bucket owner’s KMS key for encryption.
To determine if your trail is encrypted with KMS, you can check the General details section on the page for the trail. To access it, in the AWS console, navigate to the AWS Cloudtrail page, then select Dashboard, and then select your previously created trail. The encryption status will appear in the General details section, as seen in the following image.
Record the AWS KMS key value, which you will need in a subsequent procedure.
To add a KMS key to an existing trail, reference this AWS procedure: Updating a resource to use your KMS key.
Editing the IAM Policy
- In the AWS console, in the upper-left corner of the screen, click Services.
- In the menu that appears, click Security, Identity, & Compliance, and then click IAM.
The IAM page appears. - In the left pane, click Policies.
A table displaying policies appears. - Click activeeye-read-cloudtrail-policy.
The Summary page appears. - Click Edit policy.
The Edit page appears. - Click the JSON tab, and then, in the JSON code, after the first }, add the following code. Ensure that you include the comma noted below. In the following code, substitute the word KMSKEYARN with the AWS KMS key value that you recorded in the previous procedure.
,
{
"Sid": "DecryptCloudtrailKms",
"Effect": "Allow",
"Action": [
"kms:Decrypt"
],
"Resource": [
"KMSKEYARN"
]
} - Click Review policy.
- Click Save changes.
The policy is updated.
Recording the ARN Value of the Role
- In the AWS console, in the upper-left corner of the screen, click Services.
- In the menu that appears, click Security, Identity, & Compliance, and then click IAM.
The IAM page appears. - In the left pane, select Roles.
A table displaying roles appears. - Click activeeye-read-cloudtrail-role.
The Summary page appears. - Record the ARN value that appears in the middle of the page. You will need it in the next procedure.
Editing the KMS Key Policy
- In the AWS console, in the upper-left corner of the screen, click Services.
- In the menu that appears, click Security, Identity, & Compliance, and then click Key Management Service.
The Key Management Service page appears, displaying a table of customer-managed keys. - Click the alias of the KMS key that is associated with your trail.
A page displaying information about the key appears. - In the Key policy section, click the Edit button, and then, in the code, before the final ], add the following code. Ensure that you include the comma noted below. In the following code, substitute the word ROLEARN with the ARN value that you recorded in the previous procedure.
,
{
"Sid": "Allow ActiveEye to Decrypt Cloudtrail logs",
"Effect": "Allow",
"Principal": {
"AWS": "ROLEARN"
},
"Action": "kms:Decrypt",
"Resource": "*"
} - Click Save changes.
The KMS key policy is updated.
Enable Notifications To ActiveEye
Next, you will set up an SNS notification to trigger when a logfile is ready for ActiveEye to consume.
There are two ways to set this up:
- Create an S3 bucket event notification on the logging bucket: If your organization uses a centralized logging bucket, this is the recommended option. The steps required to complete this setup are described in the next procedure, Creating an S3 Bucket Event Notification.
- Enable SNS notifications on the CloudTrail configuration page itself: This setup is not covered in this document. For information on this type of setup, refer to this AWS documentation: Put Bucket Notification Configuration.
Create an S3 Bucket Event Notification
- In the AWS console, in the upper-left corner of the screen, click Services.
- In the menu that appears, click Storage, and then click S3.
The Amazon S3 page appears, displaying a table of buckets. - Select the name of the bucket for which you will enable event notification.
A page displaying details about the bucket appears. - Select the Properties tab, and then, in the Event notifications section, select Create event notification.
The Create event notification page appears.
- In the General Configuration section, in the Event Name box, enter `ActiveEye CloudTrail Notification`
- In the Event Types section, select the All object create events check box.
- In the Destination section, select the SNS topic check box, then select the Enter SNS topic ARN check box, and then, in the SNS topic box, enter the SNS Notification ARN value that you recorded in the Creating Connector Credentials for each Service Connector procedure.
- Click Save changes.
Notifications are enabled for the bucket. - As needed, repeat these steps for each S3 bucket with CloudTrail logs that needs to be monitored.
Limiting Monitoring of Accounts in the S3 Bucket
A centralized organization bucket could have CloudTrail logs for AWS accounts that are not intended to be monitored by ActiveEye. This may include sandbox accounts, demo accounts, etc.
After implementing the configuration described in the preceding Create an S3 Bucket Event Notification procedure, all CloudTrail logs will be sent to ActiveEye. There are two ways to limit the notifications to only the AWS accounts intended to be monitored by ActiveEye. For more information on these options, refer to the following AWS topics:
- Configuring event notifications using object key name filtering
- Configuring Amazon SNS notifications for CloudTrail
Verifying ActiveEye Event Ingestion
Data should now begin flowing into ActiveEye within a few minutes, depending on how frequently CloudTrail writes logfiles.
To verify that data is flowing into ActiveEye from CloudTrail, in ActiveEye, select INVESTIGATE in the left pane, and then, in the Pre-Defined Queries section, in the Cloud Infrastructure subsection, select Overview. Scroll down to the bottom of the Dashboard page that appears and, in the table, look for events with the prefix AWS Cloudtrail. If these events appear, data is flowing. Note that this page does not automatically refresh.
If you suspect an issue with the data flow, follow these troubleshooting steps.
Troubleshooting
If events have not started flowing into ActiveEye, verify the following:
- Recent CloudTrail logfiles are appearing in the S3 bucket.
- The CloudFormation stack was successfully created with the correct bucket name in the AWS account that “owns” the S3 bucket.
- The role activeeye-read-cloudtrail-role and policy activeeye-read-cloudtrail-policy appear in IAM in the AWS account that owns the S3 bucket.
- An SNS event notification is configured on the S3 bucket with the proper ARN without a bucket path prefix, the correct bucket path prefix, or that the SNS event notification is configured on the CloudTrail configuration itself with the proper ARN.
- In the ActiveEye connector credential record, verify that the bucket name is spelled correctly, and that the AWS account ID of the S3 bucket owner and the External ID match those used in the CloudFormation stack.
- In the ActiveEye service connector record, verify that the AWS account ID matches the source CloudTrail account.
- When the steps above have been completed, wait until at least 10 minutes have elapsed, and then check for results.
- If Cloudtrail is configured to use a customer-managed KMS encryption key, verify that the role and KMS policies have been updated as defined in the Enabling ActiveEye to Use the KMS Key section of this document.
Contact ActiveEye Engineering for further help troubleshooting this issue. For fastest resolution, please provide screenshots of the AWS configurations mentioned above.