TrademarkTrademark
Features
Documentation

A Guide to Terraform Audit Logs

Why are Terraform audit logs essential? What should they contain? How can they help with monitoring and workflow automation?
Ryan FeeJune 13, 2025Updated June 11, 2026
A Guide to Terraform Audit Logs
Key takeaways
  • Audit logs need to be an append-only history, not a current-state report. A usage report that only reflects the latest run can lose evidence of a malicious module within minutes of the next workspace update.
  • Auditors typically request several months of login events — successful and failed — plus administrative actions like permission changes, exported in CSV or JSON. Capture these from day one; you cannot backfill events you never recorded.
  • Streaming audit logs to Datadog or AWS EventBridge is not the same as retention. If the streaming pipeline goes down, you need an export or backfill path to recover the gap.
  • A complete Terraform audit log covers authentication events, administrative changes, variable and state access, and run lifecycle events, each with a timestamp, the acting user, and a source IP address.
  • Terraform itself does not provide a centralized, persistent audit log of user and administrative activity. Scalr generates one automatically and streams it to Datadog and AWS EventBridge as part of its Enterprise tier.

For any organization using Infrastructure as Code (IaC), maintaining a clear record of changes is a necessity for security and governance. Terraform audit logs provide this immutable record, detailing every action taken that affects your infrastructure. Effectively managing and utilizing these logs is fundamental to a secure, compliant, and operationally sound Terraform practice.

This guide explains why Terraform audit logs are essential, what information they should contain, and how you can use them for centralized monitoring and to power event-driven workflows.

Why Your Organization Needs Terraform Audit Logs

A complete audit trail answers the critical questions of who, what, and when for every change. Without a reliable system for Terraform audit logs, organizations are exposed to significant security, compliance, and operational risks.

Security and Incident Response

In the event of a security incident, Terraform audit logs are your primary source of truth. They provide a detailed timeline of events, enabling security teams to trace the origin of a breach, understand the scope of unauthorized changes, and identify the responsible party. For example, if a sensitive variable is accessed or a security group is modified, the audit log will show precisely which user or service account initiated the action, from what IP address, and at what time.

The distinction that matters here is append-only history versus current state. In May 2026, the security team at one enterprise we work with at Scalr was threat-hunting for supply-chain attacks delivered through malicious Terraform modules. They started with provider and module usage reports, then discovered those reports only reflect each workspace's most recent run: a module that appeared in the report at 8:50 AM was gone nine minutes later, after the workspace ran again with an updated configuration. Their conclusion, verbatim: "If there were an incident… we don't have a source of truth for us to search." A current-state report tells you what your infrastructure uses now; only an append-only audit log can tell you what it used at the moment of compromise.

Meeting Compliance Requirements

Many regulatory frameworks like SOC 2, HIPAA, and PCI DSS have strict requirements for logging and auditing. To pass an audit, you must be able to prove that all changes to your infrastructure are tracked and authorized. Terraform audit logs serve as the definitive evidence to satisfy auditors and demonstrate that you have control over your production environment.

What auditors actually ask for is more specific than the frameworks suggest. In May 2026, a customer preparing for a security review needed four months of records — January 1 through April 22 — covering login and access events (both successful and failed authentication) plus every administrative action: configuration changes, permission modifications, and account and user management. The auditor wanted it in CSV or JSON, in the "most detailed format available." That request shape comes up constantly in Scalr's support queue, and it has a corollary: the question about retention limits tends to arrive late. One customer, already mid-audit, asked Scalr support for twelve months of logs and only then asked what the retention window was. Confirm your retention horizon before the auditor does.

Operational Stability and Troubleshooting

When a deployment fails or an application experiences an outage, the first question engineers ask is, "What changed?" Terraform audit logs provide a clear history of all recent activities, allowing teams to quickly correlate a change with a problem. This significantly reduces mean time to resolution (MTTR) and helps prevent similar issues in the future by understanding the root cause.

What to Capture in Terraform Audit Logs

A useful audit logging system for Terraform must capture more than just run events. To provide complete visibility, your Terraform audit logs should include a wide range of activities across the platform. Key events to capture include:

  • User and Authentication Events: Logins, logouts, and failed authentication attempts.
  • Administrative Changes: Modifications to workspaces, environments, user permissions, and VCS provider settings.
  • Variable and State Access: Creation, updates, and deletions of variables (especially those marked as sensitive).
  • Run Lifecycle Events: Run creations, approvals, denials, and cancellations.
  • Object Creation/Deletion: Events for when workspaces, environments, or other resources are created or deleted.

Each log entry must contain sufficient context, including a timestamp, the user who performed the action, their source IP address, and a detailed message describing the event.

How Scalr Provides Comprehensive Terraform Audit Logs

While Terraform itself performs actions, it doesn't inherently provide a centralized, persistent audit logging system that captures the full spectrum of user and administrative activities. This is where a platform like Scalr becomes essential. Scalr is designed with auditing at its core, capturing every event that occurs within the platform.

Scalr automatically generates detailed audit logs for all the critical events, from user logins to variable creation and run approvals. These logs can be streamed to external logging platforms for administrators and security teams to consume. Audit logs and audit log streaming are part of Scalr's Enterprise tier; if compliance evidence is on your roadmap, plan for that when choosing a plan.

Centralizing Terraform Audit Logs

For enterprise-wide security monitoring and operational visibility, Terraform audit logs must be integrated with your existing observability and event management platforms. Centralizing these logs allows your teams to correlate infrastructure changes with events from other systems and apply their established monitoring, dashboarding, and alerting rules.

Scalr provides direct integrations to stream audit logs and events to leading cloud platforms.

One caveat from production experience: streaming is delivery, not retention. When a major cloud outage took down one customer's log pipeline in October 2025, their streaming destination stopped receiving events for roughly two days — October 19 through 21 — and they came to Scalr needing that window backfilled. If your compliance posture depends on an unbroken log, treat the streaming integration as one leg and keep an export or backfill path as the other. The same lesson applies after deletions: one team came to Scalr after deleting a workspace, needing the run history that went with it. Logs you have already exported survive the resources they describe.

Sending Audit Logs and Events to Datadog

Scalr can send audit logs directly to Datadog Logs. This allows you to unify your Terraform audit logs with application, security, and other infrastructure logs already being collected in Datadog. Once in Datadog, you can use its powerful search, analytics, and visualization features to create dashboards that track key Terraform activities, monitor for specific security events, and set up alerts on suspicious behavior.

Datadog audit log search results from Scalr Terraform activity

Scalr also sends events to Datadog, such as when a run errored, how the run was executed, and when. While these details are similar to audit logging, they can also be used for monitoring and alerting in event-driven workflows, as seen below.

Datadog Events Explorer showing list of Scalr Terraform run events

See the official docs on how to set up the integration with Datadog here.

Sending Audit Logs and Events to AWS Eventbridge

Scalr also sends the same audit log details to AWS Eventbridge. This integration gives users the flexibility of forwarding it to any third-party tool that Eventbridge integrates with or to another service in AWS, such as CloudWatch.

AWS CloudWatch displaying Scalr Terraform audit log events

For more than just logging, Scalr also sends events directly to an Amazon EventBridge event bus. This integration is designed for action, turning an event into a trigger. Scalr sends two event types — RunExecuted for run lifecycle and AuditLog for audit events — plus an AuditLogDisabled alert if streaming stops, which can then be used to invoke a wide range of AWS services.

See the official docs for the Scalr integration with AWS Eventbridge here.

Using Terraform Audit Logs for Event-Driven Workflows

The real power of modern audit logging comes from using events to drive automated workflows. By streaming events from Scalr to AWS EventBridge, you can move beyond passive monitoring and build active, automated systems that respond to infrastructure changes in real time.

When Scalr sends an event to your EventBridge event bus, you can create rules that filter for specific events and route them to targets. This enables powerful automation, such as:

  • Triggering an AWS Lambda function when a RunExecuted event arrives with a completed detail.status for a production environment. The function could create a change ticket in Jira, post a custom summary to a Slack channel, or run a post-deployment validation script.
  • Starting an AWS Step Functions workflow when an AuditLog event is detected with a workspace-creation detail.event. This could orchestrate a series of compliance checks, apply a standard set of policies, and notify a platform administrator that a new workspace is ready for review.
  • Sending a notification via Amazon SNS when a RunExecuted event arrives with an error detail.status. This can be used for customized email, SMS, or PagerDuty alerts that go beyond standard notifications.

By connecting the detailed events from your Terraform audit logs to a service like AWS EventBridge, your organization can build a responsive, automated, and secure infrastructure management practice.

Frequently asked questions

What should Terraform audit logs contain?

A complete Terraform audit log captures user and authentication events (including failed logins), administrative changes to workspaces and permissions, variable and state access, run lifecycle events, and object creation or deletion. Each entry needs a timestamp, the user who performed the action, their source IP address, and a detailed event description.

Why are Terraform audit logs important for compliance?

Frameworks like SOC 2, HIPAA, and PCI DSS require you to prove that all infrastructure changes are tracked and authorized. In practice, auditors ask for months of login and administrative events in an exportable format such as CSV or JSON, so the logs serve as the definitive evidence during a security review.

Does Terraform itself provide audit logs?

No. Terraform executes changes but does not provide a centralized, persistent audit logging system that captures user logins, permission changes, variable access, and run approvals. A management platform such as Scalr generates these logs automatically for every event on the platform.

Can I stream Scalr audit logs to Datadog or AWS?

Yes. Scalr streams audit logs and run events directly to Datadog Logs and to an Amazon EventBridge event bus, where they can be forwarded to CloudWatch or any EventBridge-integrated tool. Audit log streaming is part of Scalr's Enterprise tier.

Is streaming audit logs to an external platform enough for retention?

No. Streaming only delivers events while the pipeline is healthy. During the October 2025 AWS outage, one customer's streaming destination stopped receiving events for roughly two days, and they needed that window backfilled. Treat streaming as delivery and keep a separate export or backfill path for retention.
About the author
Ryan Feedirector of platform engineering at Scalr
Ryan Fee is the director of platform engineering at Scalr, with over 15 years of experience improving infrastructure experiences at companies large and small.