This repository has been archived by the owner on Aug 30, 2023. It is now read-only.
Custom/Improved Sanitize. Report* Functions. #136
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.
Changes
ReportHandler
to wrap an HTTP handler, report a panic and allow it to continue.ReportPanic
to capture a panic and report it, then allow it to continue.ReportPanicAndWait
to capture a panic and guarantee the report, then allow it to continue.Motivation
Sanitization
I pass sensitive data in not only the parameters, but the headers. In addition, the field names I use are none of the default sanitization field names. By allowing the user to specify their own field names in addition the to default, any field can be sanitized.
Report* Functions
The
Report*
family of functions was created so that a report could be sent to the service and then the panic would be allowed to continue bubbling up. This allows panic handlers further up the chain to have their turn at the panic. For example, one of my handlers recovers the panic, packages the information nicely as an error, and returns a 500 to the client.Implementation Notes
Please note, the usage of
ReportPanic(AndWait)
differs from the usage ofCapturePanic(AndWait)
. This can be changed, of course, but I feel my approach is cleaner and easier to use.Rather than having to pass a function to the
Capture*
functions, we just defer theReport*
functions directly.For example, the
Capture*
functions operate as so:Where the
Report*
functions operate like this:I feel that being able to simply defer the
Report
function allows for cleaner code, as my options when using theCapture
approach are:Capture
Capture
Capture
Each of these cases complicates the code and they all feel a bit lousy. I don't really want my function to be called by your function. I want my function to have the code right there, then your function grabs the panic and reports it, if it happens.