-
Notifications
You must be signed in to change notification settings - Fork 42
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
feature(deadline): Enable logging for DocDB #37
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We use CDK construct for DocumentDB so we only can fix it in our example.
I do not believe this statement. Anything that can be done in the application code can be done in the Repository. The ask, for the Repository, is to design an interface (similar to what Dave did for the ALB) that allows a customer to tell the Repository to enable audit logging when/if the Repository creates a DocDB database for the customer (i.e. if it's not being provided one).
Especially since the thinking is to remove the kitchen sink example from the repo once we have a solid set of official samples in place.
7d85cea
to
a5bfbdb
Compare
* For more information about audit logging in DocumentDB, see: https://docs.aws.amazon.com/documentdb/latest/developerguide/event-auditing.html | ||
* | ||
*/ | ||
export class DocumentDbClusterWithLogs extends DatabaseCluster { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ideally we should upstream these changes to the DatabaseCluster
class in CDK so we can simply add a new property for the audit logging stuff (e.g. auditLogging?: AuditLoggingProps
). If we are short on time though, this will have to do for now. Thoughts @ddneilson ?
70d30ca
to
af7afdc
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just the comment on the parameter group descriptions then this looks good to me.
af7afdc
to
cfbc11f
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good!
cfbc11f
to
4321ca1
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I have 2 more comments for this one:
- The merge request title needs to be updated since you are adding a feature to the Repository not adding to the example
- This MR requires Tests for the new functionality that was added to the Repository.
4321ca1
to
d0e1b92
Compare
d0e1b92
to
eafb89c
Compare
expectCDK(stack).to(haveResourceLike('AWS::DocDB::DBInstance', { | ||
AutoMinorVersionUpgrade: true, | ||
})); | ||
}); | ||
|
||
test('audit log is disabled when it required', () => { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This test title is kind of awkward. Can we instead have it be something along the lines of
Disabling Audit logging removes parameters
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It is not actually remove parameters, it switching audit log off.
What about Disabling Audit logging does not enable audit logging
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Compared to the default it is removing the parameters to switch of auditing.
But sure your naming should work.
62e5296
to
820a5a9
Compare
820a5a9
to
73ed0d6
Compare
This fix DocDB part of the issue discovered during the security audit
Was added class that can be used if customer want to switch audit log.
Description of how audit log can be enabled is here
In repository constructor was added
databaseAuditLogging
parameter and according to value of this parameter enable audit logging for DocDB cluster.Also was added example code in kitchen sink.
Was enabled parameter
audit_logs
and addedaudit
toenableCloudwatchLogsExports
construct option.Testing
Was deployed kitchen sink with this changes and checked that CloudWatch logs enabled
data:image/s3,"s3://crabby-images/5c060/5c060b02074f4d5db537b5f5a936a4c7d338fbf2" alt="image"
Checking CloudWatch that audit log group was created and messages appeared.