Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(rds): default DatabaseCluser and DatabaseInstance storageEncrypted to true (under feature flag) #32695

Open
wants to merge 25 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 7 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
d80befc
chore: add feature flag
blimmer Dec 31, 2024
ff3521d
feat: enable cluster encryption by default under feature flag
blimmer Dec 31, 2024
319e467
fix: add isStorageLegacyUnencrypted to work around false/undefined on…
blimmer Dec 31, 2024
83d402d
fix: existing integration tests
blimmer Dec 31, 2024
9ce2d46
docs: add readme note about encryption
blimmer Dec 31, 2024
221b872
feat: enable encryption by default for db instances
blimmer Dec 31, 2024
75192b0
fix: existing integration tests
blimmer Dec 31, 2024
04fe2b2
fix: add default properties
blimmer Dec 31, 2024
d1c6c06
feat: add cluster integ test
blimmer Dec 31, 2024
576289e
fix: code sample in readme
blimmer Dec 31, 2024
6bd263d
feat: add instance integ test
blimmer Dec 31, 2024
da306c0
chore: add tests for thrown error
blimmer Dec 31, 2024
6077185
fix: sync snapshot
blimmer Dec 31, 2024
4497f62
Merge branch 'main' into enable-rds-encryption-by-default
blimmer Dec 31, 2024
c089ab2
Merge branch 'main' of github.com:blimmer/aws-cdk into enable-rds-enc…
blimmer Jan 4, 2025
dbea499
refactor: isStorageLegacyUnencrypted -> storageEncryptedLegacyDefault…
blimmer Jan 4, 2025
4af1515
fix: merge conflict issue with feature flag markdown
blimmer Jan 4, 2025
3c317b0
refactor: common `getStorageEncryptedProperty` implementation
blimmer Jan 4, 2025
26a9325
fix: again
blimmer Jan 4, 2025
82f8e77
docs: rework docs
blimmer Jan 4, 2025
9130e4e
Merge branch 'main' of github.com:blimmer/aws-cdk into enable-rds-enc…
blimmer Jan 6, 2025
1086ef1
fix: union type
blimmer Jan 6, 2025
a327f10
docs: readme update
blimmer Jan 6, 2025
becf0a7
fix: method signature
blimmer Jan 6, 2025
14795d0
Merge branch 'main' of github.com:blimmer/aws-cdk into enable-rds-enc…
blimmer Jan 8, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,8 @@ class TestStack extends cdk.Stack {
vpc,
Copy link
Contributor Author

@blimmer blimmer Dec 31, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This change affected a lot of integration tests. I opted to use the legacy behaviors for these tests because re-running the creation of all these databases would be extremely slow and expensive.

If someone at AWS with a "free"/"expensed" account would like to rerun all these failing tests, we could go that route, too.

I added explicit new tests for this behavior.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think manually adding "StorageEncrypted": true to the templates would make those tests pass without the need to deploy the related resources (we expect the flag to work given that you added the new test).

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In the past, I've received PR feedback that you should never manually update snapshot files. I just confirmed that I could add this property manually to the snapshots and that would be an alternative solution to updating the stack definitions.

I'd like a +1 from an approver that this would be OK before I spend the time doing it, based on previous feedback that snapshots should never be manually edited.

Copy link
Contributor

@lpizzinidev lpizzinidev Jan 4, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've received PR feedback that you should never manually update snapshot files

👍 Sounds good!

About the isStorageLegacyUnencrypted comment.
Thanks for clarifying, I'm not sure why CFN defaults to unencrypted clusters and instances.
However, I left some comments on the implementation for small adjustments.

credentials: rds.Credentials.fromGeneratedSecret('clusteradmin', credentialsBaseOptions),
defaultDatabaseName: 'integdb',
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

const secret = secretmanager.Secret.fromSecretNameV2(this, 'Secret', 'integ-secretName');
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,8 @@ const cluster = new rds.DatabaseCluster(stack, 'Database', {
writer: rds.ClusterInstance.serverlessV2('writerInstance'),
vpc,
enableDataApi: true,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

const importedCluster = rds.DatabaseCluster.fromDatabaseClusterAttributes(stack, 'ImportedCluster', {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,8 @@ const cluster = new rds.DatabaseCluster(stack, 'Database', {
writer: rds.ClusterInstance.serverlessV2('writerInstance'),
vpc,
enableDataApi: true,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

cluster.grantDataApiAccess(fucntion);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,8 @@ new rds.DatabaseCluster(stack, 'DualstackCluster', {
vpcSubnets: { subnetType: ec2.SubnetType.PRIVATE_ISOLATED },
vpc,
networkType: rds.NetworkType.DUAL,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
removalPolicy: cdk.RemovalPolicy.DESTROY,
});

Expand All @@ -49,6 +51,8 @@ new rds.DatabaseCluster(stack, 'Ipv4Cluster', {
}),
],
networkType: rds.NetworkType.IPV4,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
removalPolicy: cdk.RemovalPolicy.DESTROY,
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@ new rds.DatabaseCluster(stack, 'DatabaseCluster', {
rds.ClusterInstance.serverlessV2('readerInstance1'),
],
vpc,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
enableLocalWriteForwarding: true,
});

Expand All @@ -25,6 +27,8 @@ new rds.DatabaseCluster(stack, 'DatabaseClusterPostgresql', {
rds.ClusterInstance.serverlessV2('readerInstance1'),
],
vpc,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
enableLocalWriteForwarding: true,
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@ new rds.DatabaseCluster(stack, 'Database', {
engine: rds.DatabaseClusterEngine.auroraPostgres({ version: rds.AuroraPostgresEngineVersion.VER_16_1 }),
writer: rds.ClusterInstance.serverlessV2('writerInstance'),
vpc,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
monitoringInterval: cdk.Duration.seconds(5),
enableClusterLevelEnhancedMonitoring: true,
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,8 @@ new DatabaseCluster(stack, 'Database', {
...instanceProps,
}),
],
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

new IntegTest(app, 'cdk-rds-cluster-instance-ca-certificate-test', {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,8 @@ new rds.DatabaseCluster(stack, 'Database', {
readers: [rds.ClusterInstance.provisioned('reader')],
instanceUpdateBehaviour: rds.InstanceUpdateBehaviour.ROLLING,
vpc,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

new integ.IntegTest(app, 'instanceIdentifiersTest', {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,8 @@ const cluster = new DatabaseCluster(stack, 'Database', {
vpc,
},
storageType: DBClusterStorageType.AURORA_IOPT1,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

cluster.connections.allowDefaultPortFromAnyIpv4('Open to the world');
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,8 @@ new rds.DatabaseCluster(stack, 'Database', {
vpc,
domain: activeDirectory.ref,
domainRole: iamRole,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

new integ.IntegTest(app, 'integ-cluster-kerberos', {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,8 @@ class TestStack extends cdk.Stack {
enableClusterLevelEnhancedMonitoring: true,
storageType: DBClusterStorageType.AURORA_IOPT1,
cloudwatchLogsExports: ['postgresql'],
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,8 @@ class TestStack extends cdk.Stack {
readers: [ClusterInstance.provisioned('reader', {
instanceType: ec2.InstanceType.of(ec2.InstanceClass.R7G, ec2.InstanceSize.LARGE),
})],
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,8 @@ export class TestStack extends Stack {
vpcSubnets: {
subnetType: SubnetType.PUBLIC,
},
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
}));
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@ const cluster = new rds.DatabaseCluster(stack, 'Database', {
...instanceProps,
}),
],
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

cluster.addRotationSingleUser();
Expand All @@ -48,6 +50,8 @@ const clusterWithCustomRotationOptions = new rds.DatabaseCluster(stack, 'CustomR
...instanceProps,
}),
],
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});
clusterWithCustomRotationOptions.addRotationSingleUser({
automaticallyAfter: cdk.Duration.days(7),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,8 @@ new rds.DatabaseCluster(stack, 'Database', {
vpc,
s3ImportBuckets: [importExportBucket],
s3ExportBuckets: [importExportBucket],
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

new IntegTest(app, 'aws-cdk-rds-s3-mysql-8-integ-test', {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,8 @@ class PostgresS3TestStack extends cdk.Stack {
vpc,
s3ImportBuckets: [importExportBucket],
s3ExportBuckets: [importExportBucket],
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,8 @@ const cluster = new DatabaseCluster(stack, 'Database', {
storageEncryptionKey: kmsKey,
s3ImportBuckets: [importBucket],
s3ExportBuckets: [exportBucket],
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

cluster.connections.allowDefaultPortFromAnyIpv4('Open to the world');
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@ export class TestStack extends Stack {
writer: ClusterInstance.serverlessV2('writer'),
removalPolicy: RemovalPolicy.DESTROY,
vpc: vpc,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@ export class TestStack extends Stack {
writer: ClusterInstance.serverlessV2('writer'),
removalPolicy: RemovalPolicy.DESTROY,
vpc: vpc,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ class TestCase extends Construct {
readers: props.readers,
removalPolicy: RemovalPolicy.DESTROY,
vpc: props.vpc,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});
cluster.metricServerlessDatabaseCapacity({
period: Duration.minutes(10),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@ class TestStack extends Stack {
}),
],
vpc,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
removalPolicy: RemovalPolicy.DESTROY,
});

Expand All @@ -53,6 +55,8 @@ class TestStack extends Stack {
],
vpc,
removalPolicy: RemovalPolicy.DESTROY,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});
fromSnapshot.addRotationSingleUser();
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@ new DatabaseInstance(stack, 'Instance', {
}),
instanceType: InstanceType.of(InstanceClass.T3, InstanceSize.MICRO),
vpc,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
caCertificate: CaCertificate.RDS_CA_RSA2048_G1,
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,8 @@ const instance = new rds.DatabaseInstance(stack, 'Instance', {
deletionProtection: false,
publiclyAccessible: false,
backupRetention: cdk.Duration.days(0),
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

const role = new iam.Role(stack, 'DBRole', {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,8 @@ new rds.DatabaseInstance(stack, 'DualstackInstance', {
multiAz: false,
publiclyAccessible: false,
networkType: rds.NetworkType.DUAL,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
removalPolicy: cdk.RemovalPolicy.DESTROY,
});

Expand All @@ -35,6 +37,8 @@ new rds.DatabaseInstance(stack, 'Ipv4Instance', {
multiAz: false,
publiclyAccessible: false,
networkType: rds.NetworkType.IPV4,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
removalPolicy: cdk.RemovalPolicy.DESTROY,
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@ class TestStack extends Stack {
vpc,
allocatedStorage: 1000,
storageType: StorageType.GP3,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
removalPolicy: RemovalPolicy.DESTROY,
});
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ new DatabaseInstance(stack, 'Instance', {
},
allocatedStorage: 1000,
storageType: StorageType.IO2,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
removalPolicy: RemovalPolicy.DESTROY,
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,8 @@ new rds.DatabaseInstance(stack, 'Database', {
instanceType: ec2.InstanceType.of(ec2.InstanceClass.BURSTABLE3, ec2.InstanceSize.MEDIUM),
vpc,
domain: activeDirectory.ref,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

new integ.IntegTest(app, 'integ-instance-kerberos-without-domainRole', {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,8 @@ new rds.DatabaseInstance(stack, 'Database', {
vpc,
domain: activeDirectory.ref,
domainRole: iamRole,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

new integ.IntegTest(app, 'integ-instance-kerberos', {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@ new rds.DatabaseInstance(stack, 'Instance', {
iamAuthentication: true,
s3ImportBuckets: [new s3.Bucket(stack, 'ImportBucket', { removalPolicy: cdk.RemovalPolicy.DESTROY })],
s3ExportBuckets: [new s3.Bucket(stack, 'ExportBucket', { removalPolicy: cdk.RemovalPolicy.DESTROY })],
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
removalPolicy: cdk.RemovalPolicy.DESTROY,
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ new DatabaseInstance(stack, 'Database', {
licenseModel: LicenseModel.LICENSE_INCLUDED,
s3ImportBuckets: [importBucket],
s3ExportBuckets: [exportBucket],
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
removalPolicy: cdk.RemovalPolicy.DESTROY,
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,8 @@ const instance = new rds.DatabaseInstance(stack, 'Instance', {
iamAuthentication: true,
cloudwatchLogsExports: ['postgresql'],
cloudwatchLogsRetention: logs.RetentionDays.THREE_MONTHS,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
removalPolicy: cdk.RemovalPolicy.DESTROY,
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,8 @@ new rds.DatabaseInstance(stack, 'Instance', {
publiclyAccessible: true,
iamAuthentication: true,
parameterGroup,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
removalPolicy: cdk.RemovalPolicy.DESTROY,
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,8 @@ const mariaDBInstance = new rds.DatabaseInstance(stack, 'mariaDBInstance', {
excludeCharacters: '"@/\\',
}),
vpc,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
removalPolicy: RemovalPolicy.DESTROY,
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,8 @@ const dbInstance = new rds.DatabaseInstance(stack, 'SqlServerDbInstance', {
}),
vpc,
licenseModel: LicenseModel.LICENSE_INCLUDED,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
removalPolicy: RemovalPolicy.DESTROY,
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,8 @@ const dbInstance = new rds.DatabaseInstance(stack, 'dbInstance', {
excludeCharacters: '"@/\\',
}),
vpc,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
removalPolicy: RemovalPolicy.DESTROY,
});

Expand All @@ -38,6 +40,8 @@ const cluster = new rds.DatabaseCluster(stack, 'dbCluster', {
version: rds.AuroraPostgresEngineVersion.VER_14_5,
}),
instanceProps: { vpc },
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

// The `DatabaseProxy` internally adds a dependency so that the `TargetGroup` is created after the `DatabaseCluster` is created.
Expand All @@ -60,6 +64,8 @@ const clusterWithWriterAndReaders = new rds.DatabaseCluster(stack, 'dbClusterWit
vpc,
writer: rds.ClusterInstance.provisioned('writer'),
readers: [rds.ClusterInstance.provisioned('reader')],
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

new rds.DatabaseProxy(stack, 'Proxy3', {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@ const mysqlSource = new rds.DatabaseInstance(stack, 'MysqlSource', {
backupRetention: Duration.days(5),
instanceType: InstanceType.of(InstanceClass.T3, InstanceSize.SMALL),
vpc,
storageEncrypted: false,
isStorageLegacyUnencrypted: true,
});

new rds.DatabaseInstanceReadReplica(stack, 'MysqlReplica', {
Expand Down
Loading
Loading