proposal(op): enhance the handling of authentication response for prompt=none
#728
+410
−27
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Summary of Changes
Improved authentication request handling by extracting the CallbackURL generation logic. This allows for direct redirection to the CallbackURL for
prompt=none
requests.Key Changes
AuthResponseCode
functionBuildAuthResponseCodeResponsePayload
andBuildAuthResponseCallbackURL
Motivation
This change addresses the need to optimize authentication requests with
prompt=none
. Currently, theAuthorize
method in theServer
interface can only return aRedirect
struct and doesn't have direct access to HTTP request/response objects.To streamline the authentication flow, we need to generate a callback URL directly and redirect to it when
prompt=none
is specified. However, in the current implementation, the authorization code generation and callback URL creation process depends onhttp.ResponseWriter
andhttp.Request
, making it difficult to reuse for this purpose.This change extracts key logic into reusable functions, enabling more efficient handling of special cases like
prompt=none
in future implementations.Usage
We expect to use these functions when handling
prompt=none
, as shown below.Impact
This change improves internal implementation without affecting the public API. All existing behavior is preserved.
Definition of Ready