You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
This is in reference to: #183 posted back in 2016 that was closed by saying the solution was to register a handler as a singleton.
There are multiple reasons why you should not do this, but one of them being that handlers can be configurable so that they can be re-used with multiple http clients and configured on a per-client basis. Consider a handler called OAuthHandler where the constructor takes in IOptionsSnapshot<OAuthHandlerOptions>. This allows me to have two different HttpClient instances that can both use the same handler type to authenticate with two different OAuth endpoints by configuring each handler per the client's needs.
Another reason has to do with DNS changes which was one of the driving forces that IHttpClientFactory was intended to solve.
I don't believe, however, that making an alteration to ignore the DelegatingHandler type from the AddTransient call is the answer, because there could also be other exceptions to this rule for other things within the framework. Maybe this is a configuration that SimpleInjector can read in to know that "Here's a list of exceptions to the rule for disposing transients." or something to that effect.
The text was updated successfully, but these errors were encountered:
I agree with this as well. We are running into a use case where we would like to provide a cloud provider handler to get information back for that specific cloud provider and being able to pass in the option on which cloud provider is being used for this HttpClient usage. Otherwise you would need a separate handler for each cloud provider to do the exact same function, which seems like a violation of DRY.
This is in reference to: #183 posted back in 2016 that was closed by saying the solution was to register a handler as a singleton.
There are multiple reasons why you should not do this, but one of them being that handlers can be configurable so that they can be re-used with multiple http clients and configured on a per-client basis. Consider a handler called OAuthHandler where the constructor takes in
IOptionsSnapshot<OAuthHandlerOptions>
. This allows me to have two different HttpClient instances that can both use the same handler type to authenticate with two different OAuth endpoints by configuring each handler per the client's needs.Another reason has to do with DNS changes which was one of the driving forces that IHttpClientFactory was intended to solve.
I don't believe, however, that making an alteration to ignore the DelegatingHandler type from the AddTransient call is the answer, because there could also be other exceptions to this rule for other things within the framework. Maybe this is a configuration that SimpleInjector can read in to know that "Here's a list of exceptions to the rule for disposing transients." or something to that effect.
The text was updated successfully, but these errors were encountered: