providers/oauth2: ensure response is URL fragment only when implicit or hybrid

This commit is contained in:
Jens Langhammer 2020-12-27 18:15:02 +01:00
parent ce9fb8801c
commit 378fe38b12

View file

@ -95,7 +95,7 @@ class OAuthAuthorizationParams:
# Because in this endpoint we handle both GET
# and POST request.
query_dict = request.POST if request.method == "POST" else request.GET
state = query_dict.get("state", "")
state = query_dict.get("state")
redirect_uri = query_dict.get("redirect_uri", "")
response_type = query_dict.get("response_type", "")
@ -192,12 +192,15 @@ class OAuthAuthorizationParams:
def check_nonce(self):
"""Nonce parameter validation."""
if not self.nonce:
self.nonce = self.state
LOGGER.warning("Using state as nonce for OpenID Request")
if not self.nonce:
if SCOPE_OPENID in self.scope:
LOGGER.warning("Missing nonce for OpenID Request")
raise AuthorizeError(
self.redirect_uri, "invalid_request", self.grant_type, self.state
)
self.nonce = ""
def check_code_challenge(self):
"""PKCE validation of the transformation method."""
@ -354,10 +357,17 @@ class OAuthFulfillmentStage(StageView):
self.params.state,
)
uri = uri._replace(
query=urlencode(query_params, doseq=True),
fragment=uri.fragment + urlencode(query_fragment, doseq=True),
)
replace_kwargs = {}
if self.params.grant_type in [GrantTypes.IMPLICIT, GrantTypes.HYBRID]:
replace_kwargs = {
"fragment": uri.fragment + urlencode(query_fragment, doseq=True),
}
else:
replace_kwargs = {
"query": urlencode(query_params, doseq=True),
}
uri = uri._replace(**replace_kwargs)
return urlunsplit(uri)