-
Notifications
You must be signed in to change notification settings - Fork 764
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
[API Proposal]: Allow retrieval of HttpRequestMessage from Polly.Context
#4957
Comments
Given you are the main expert on this, are you expecting any feedback from anyone else @martintmk or is this ready for review? |
I believe this is ready for review. |
@martintmk I'd love to see this built in! We're trying to rollout new v8 policy guidance & extensions for our enterprise and using information from the request message in our Retry logging is a common use case. |
@martintmk I have 2 questions:
Apart from that, the proposal looks good to me. |
Hey @iliar-turdushev
Yup, they can also access the request message, extract some information and use it for telemetry. The latter was my primary motivation for these APIs.
I think we shall still keep the option to "reset" the request message. So my vote would be to keep the nullable option. |
LGTM. |
Approved. @martintmk feel free to send a pull-request with the necessary changes, if you fancy it. |
The implementation is blocked because of the following issue in Polly App-vNext/Polly#2299. The issue doesn't allow us to make public static void SetRequestMessage(this ResilienceContext context, HttpRequestMessage? requestMessage); @martintmk Do we really want to allow |
Here, I wanted to mimic the behavior of Another scenario where setting the null can be valuable is the |
Updates Polly libraries to version 8.4.2
Adds extension methods allowing retrieval of the request message from resilience context
Replaces usage of ResilienceKeys.RequestMessage variable with corresponding Get/Set methods
Marks new API as Experimental
Background and motivation
Clients using new resilience APIs based on top of Polly v8 might want to access
HttpRequestMessage
associated with the attempt being executed. This would allow the following scenarios:Metering Enrichment
Client can decide to add additional metrics extracted from
HttpRequestMessage
using metering enrichment.Custom Routing
For hedging or retries, the client might decide to change the URL for secondary attempts. This would also enable dynamic URL resolution.
Access to
HttpRequestMessage
in callbacksFor logging/other purposes the client uses callbacks and can be interested in the current request message.
API Proposal
API Usage
The example above demonstrates how the new API can be used to change the URL of outgoing request. Similar approach can be used for retries or telemetry enrichment.
Alternative Designs
The above example can be rewritten as:
However, this relies on some internal naming:
https://github.com/dotnet/extensions/blob/a8e17517bd5150cc0f992b66aa6591c7c6fbdfc4/src/Libraries/Microsoft.Extensions.Http.Resilience/Internal/ResilienceKeys.cs#L13C92-L13C122
It would be better to have built-in support for retrieving
HttpRequestMessage
fromResilienceContext
as I suspect this will be a common scenario.Risks
Caller retrieving and modifying
HttpRequestMessage
associated with the current attempt in a non-compatible way or doing some changes that will corrupt the request.The text was updated successfully, but these errors were encountered: