[12.x] Log: Add optional keys parameter to Log::withoutContext
to remove selected context from future logs
#55181
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Description
This PR adds an optional
$keys
parameter to thewithoutContext
method, allowing to selectively remove specific context keys from the logger instance.When no keys are provided, existing behaviour is not changed - the method continues to clear all context as before.
Thanks to @slashequip for the inspiration 💜
Benefits
withoutContext
usageExample
The
withoutContext
method can now be used to remove specific context keys while preserving others:Why?
We want to lean more into using withContext, but can end up polluting the context when using our actions within http requests, queued jobs, commands. It means we usually end up repeating the context throughout more complex actions in order to not pollute other logs created from outside of the action.