Skip to main content
MEDIUMS3Cost Optimization

S3 Lifecycle Policy Missing

s3-lifecycle-policy-missing

What this rule checks

Detects S3 buckets without lifecycle policies.

How to fix it

  1. 1Create lifecycle rules to transition objects to cheaper storage classes
  2. 2Set expiration rules for temporary data
  3. 3Use lifecycle rules to delete incomplete multipart uploads
FlaggedThe bucket has no lifecycle rules, so objects accumulate indefinitely at Standard-storage prices and old versions are never cleaned up.
import { Bucket } from 'aws-cdk-lib/aws-s3';

new Bucket(this, 'DataBucket');
FixedA lifecycle rule transitions objects to Glacier after 90 days and expires them after 365, populating LifecycleConfiguration.Rules and controlling storage cost.
import { Duration } from 'aws-cdk-lib';
import { Bucket, StorageClass } from 'aws-cdk-lib/aws-s3';

new Bucket(this, 'DataBucket', {
  lifecycleRules: [{
    transitions: [{ storageClass: StorageClass.GLACIER, transitionAfter: Duration.days(90) }],
    expiration: Duration.days(365),
  }],
});

CDK Insights pinpoints the exact file and line in your CDK source for every finding, so you can jump straight to the fix.

Affected resource types

AWS::S3::Bucket

AWS documentation

Read the AWS guidance

Intentional? Suppress this finding

Sometimes a flag is deliberate โ€” a genuinely public endpoint, say. You can dismiss s3-lifecycle-policy-missing and the reason is kept in the report, not silently hidden.

In .cdk-insights.json:

{
  "ignoreRules": [
    { "id": "s3-lifecycle-policy-missing", "reason": "Why this is intentional" }
  ]
}

Or inline in your CDK code:

Validations.of(scope).acknowledge({
  id: 'cdk-insights::s3-lifecycle-policy-missing',
  reason: 'Why this is intentional',
});

Use the rule ID s3-lifecycle-policy-missing shown above โ€” not the CDK-* ID from SARIF / GitHub code scanning. To dismiss every finding on one construct instead, use ignorePaths. Suppression docs โ†’

Catch this in your stack

$ npx cdk-insights scan

CDK Insights runs this and 118+ other rules locally against your synthesised CDK app โ€” free, no account, your code never leaves your machine.

More S3 rules