-
Notifications
You must be signed in to change notification settings - Fork 189
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
The Implicit Flow: Part 1 #107
Conversation
# Conflicts: # lib/omniauth/openid_connect/version.rb
lib/omniauth/openid_connect.rb
Outdated
@@ -2,4 +2,5 @@ | |||
|
|||
require 'omniauth/openid_connect/errors' | |||
require 'omniauth/openid_connect/version' | |||
require 'omniauth/strategies/openid_connect' | |||
#require 'omniauth/strategies/openid_connect' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why is this commented out?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Because omniauth/strategies/openid_connect
is not a subdirectory. This is required from lib/omniauth_openid_connect
.
Co-authored-by: Stan Hu <[email protected]>
# Conflicts: # test/lib/omniauth/strategies/openid_connect_test.rb # test/test_helper.rb
raise ArgumentError, 'Not supported response_type' | ||
end | ||
|
||
if configured_response_type == 'id_token token' && |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
response_type
can also be:
token
token id_token token
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
No. token
(raw OAuth 2.0) MUST NOT be used for the authentication purpose. There are many explanations, for example, see: http://www.thread-safe.com/2012/01/problem-with-oauth-for-authentication.html
Acceptable:
code
- Authorization Code Flowid_token token
- Implicit Flowcode id_token
- Hybrid Flow -- Financial-grade API Security Profile 1.0 - Part 2: Advanced
However, I think i will implement the Implicit Flow first. After finishing, I will consider whether to implement the Hybrid Flow.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This method name setup_phase
is confusing; maybe validate_response_type!
is better. My point is there are many types of response_type
values, and it's not clear to me that this is checking specific types for different flows.
We may want to link: https://openid.net/specs/oauth-v2-multiple-response-types-1_0-03.html
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
setup_phase
is a override method. It's OK.
As you say, there are various combinations of response_type
. However, they cannot be implemented without checking the use cases and risks one by one.
If you want to implement the Hybrid Flow, I won't stop it and welcome you to do it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see your security note about id_token
, but this gem supported that configuration in the past (e.g. https://docs.microsoft.com/en-us/azure/active-directory/develop/v2-protocols-oidc#send-the-sign-in-request). I'm a bit hesitant to break existing configurations.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There are too many things to point out and I am at a loss.
- The Implicit Flow of this branch does not force the public key verification required by the specification and does not secure. So I'm trying to make it.
- The compatibility with what does not work. What does that mean?
- As stated in the link you shared, Azure AD disables the Implicit Flow by default.
- I'm using Azure AD, so I checked. You can enable the implicit permissions on the Azure AD console. However, in the description there,
id_token token
is specified. In the case of the Hybrid Flow, enabling onlyid_token
is instructed. - The Hybrid Flow is not the scope of this patch sequence.
Furthermore, if you still want to get id_token
only, OK, I consider implementing it. Let me do to accept only id_token
in the next patch part 2 and implement the public key validation in patch part 3.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@stanhu
Are there any additions? For reference, I would link to the implementation guide.
https://openid.net/specs/openid-connect-implicit-1_0.html
|
||
options.issuer = issuer if options.issuer.nil? || options.issuer.empty? | ||
|
||
verify_id_token!(params['id_token']) if configured_response_type == 'id_token' | ||
verify_id_token!(params['id_token']) if configured_response_type == 'id_token token' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think there should be some method for implicit_flow?
, client_credentials_flow?
, etc. There are many possibilities for configured_response_type
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah, I see.
I want to organize it with the patch part 2 to push next.
# Conflicts: # test/lib/omniauth/strategies/openid_connect_test.rb # test/test_helper.rb
Some people (me) may get a bit confused with the use-case you are trying to cover. BTW, my expectation is that I may be just about to learn something. |
@formigarafa
Do you know what a use case was expected when the first Implicit Flow was introduced? |
The review takes a lot of time. |
My concern is just if it would become possible to create an implicit flow on server-side with your changes which I believe is supposed to be avoided. I have been reading and it seem there are other less conventional flows using the name implicit. I wonder if what you are implementing would be one of those. It would be nice to have a link or description to give an overview of what the code is supposed to do. It will ease reviews by knowing what is new and if something is breaking in the process. |
Closes [omniauth#105][] Similar to [omniauth#107][] Some OpenID compatible IdP support hybrid authorizations that accept a `response_type` with both `code` and `id_token`. For example, [Microsoft Azure B2C][] accepts them as a URL-encoded array: > `response_type`: Must include an ID token for OpenID Connect. If your web application also needs tokens for calling a web API, you can use `code+id_token`. This commit extends the `OmniAuth::Strategies::OpenIDConnect` to encode the `response_type` into the query parameter as space-delimited token list when provided as an array. Similarly, when checking for missing keys in the response, iterate over the values as if they're an array. For the originally supported single-value case, the previous behavior is maintained. [Microsoft Azure B2C]: https://learn.microsoft.com/en-us/azure/active-directory-b2c/openid-connect#send-authentication-requests [omniauth#105]: omniauth#105 [omniauth#107]: omniauth#107
Closes [omniauth#105][] Similar to [omniauth#107][] Some OpenID compatible IdP support hybrid authorizations that accept a `response_type` with both `code` and `id_token`. For example, [Microsoft Azure B2C][] accepts them as a URL-encoded array: > `response_type`: Must include an ID token for OpenID Connect. If your web application also needs tokens for calling a web API, you can use `code+id_token`. This commit extends the `OmniAuth::Strategies::OpenIDConnect` to encode the `response_type` into the query parameter as space-delimited token list when provided as an array. Similarly, when checking for missing keys in the response, iterate over the values as if they're an array. For the originally supported single-value case, the previous behavior is maintained. [Microsoft Azure B2C]: https://learn.microsoft.com/en-us/azure/active-directory-b2c/openid-connect#send-authentication-requests [omniauth#105]: omniauth#105 [omniauth#107]: omniauth#107
Closes [omniauth#105][] Similar to [omniauth#107][] Some OpenID compatible IdP support hybrid authorizations that accept a `response_type` with both `code` and `id_token`. For example, [Microsoft Azure B2C][] accepts them as a URL-encoded array: > `response_type`: Must include an ID token for OpenID Connect. If your web application also needs tokens for calling a web API, you can use `code+id_token`. This commit extends the `OmniAuth::Strategies::OpenIDConnect` to encode the `response_type` into the query parameter as space-delimited token list when provided as an array. Similarly, when checking for missing keys in the response, iterate over the values as if they're an array. For the originally supported single-value case, the previous behavior is maintained. [Microsoft Azure B2C]: https://learn.microsoft.com/en-us/azure/active-directory-b2c/openid-connect#send-authentication-requests [omniauth#105]: omniauth#105 [omniauth#107]: omniauth#107
The Implicit Flow: Part 1.
It's quite a big deal, so I split it into several patches.
I have checked that I don't break the Code Flow.
AS-IS:
The Implicit Flow is used in a situation when the
client_secret
cannot be kept safe.So, the client must validate the token returned by the IdP with the IdP's public key.
However, neither the strategy code nor the test cases have been validated and tested. It is vulnerable.
In this Part 1, I prepare the flow to incorporate verification.
options:
response_type: ['id_token','token']
You must use always the IdP's RSA public key.
discovery:false
.public_key()
is restricted to only public keys.public_key()
fromkey_or_secret()
at necessaryconfigured_response_type()
others:
coveralls
dependency removed due to version conflict.