Skip to content
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

HTTP reconfiguration #84

Open
fmang opened this issue Apr 24, 2023 · 2 comments
Open

HTTP reconfiguration #84

fmang opened this issue Apr 24, 2023 · 2 comments

Comments

@fmang
Copy link

fmang commented Apr 24, 2023

Greetings,

Thank you for all the gems.

In order to reconfigure the Faraday client OpenIDConnect uses, I have tried the following:

OpenIDConnect.http_config { |faraday|  }
# Do something.

OpenIDConnect.http_config { |faraday|  }
# Do something with different settings.

However, this doesn’t work because OpenIDConnect.http_config only accepts the first configuration, and so do the gems for the sub-protocols.

def self.http_config(&block)
@sub_protocols.each do |klass|
klass.http_config(&block) unless klass.http_config
end
@@http_config ||= block
end

I believe calling http_config multiple times should instead either sum the configurations (by storing the blocks in an array, for instance), or overwrite the configuration each time it is called. In the latter case, an explicit setter would be more intuitive, though slightly more verbose:

OpenIDConnect.http_config = ->(faraday) {  }

As a workaround, I have resorted to setting @@http_config directly instead, but that feels pretty hacky. I have noticed that Rack::OAuth2 provides a reset_http_config! method instead, but the other gems don’t, and a setter would feel more natural anyway.

Alternatively, I wish I could pass my HTTP configuration every time I instantiate a class that performs HTTP requests rather than rely on a global state.

Best regards.

@gl-johnson
Copy link

gl-johnson commented Jul 11, 2023

We have a need for this as well. Would like to be able to define a custom SSL config on a per-connection basis. We'd like to to support multiple OIDC providers where some of them may have custom CA certs and/or proxies that need to be able to pass TLS verification, with the user being able to configure the needed CA certs in the app.

Any plans to implement or accept contributions around this enhancement? Thanks!

@nov
Copy link
Owner

nov commented Jan 3, 2024

understood the needs, but no good idea at this time.
I want to limit the scope of http_config like

OpenIDConnect.debug do
  # in debugging mode
end

# not in debugging mode

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants