"Redirect after login to destination URL" no longer works

Created on 9 February 2024, about 1 year ago

Problem/Motivation

I believe πŸ› RuntimeException: Failed to start the session because headers have already been sent Fixed #3246475: Cache Metadata Leak in UserLoginController β†’ introduces a bunch of exit; calls to mitigate an issue relating to metadata leakage.

However, this isn't advisable especially in an OOP context like Symfony, this essentially short-circuits other actions that Drupal or other modules might need to run during the login process such as setting a temporary session to store the destination URL it needs to redirect back to etc.

Steps to reproduce

Enable the "Redirect after login to destination URL" option in /admin/config/system/o365/settings/sso

Then attempt to login to a page using /o365/login/custom_connector?destination=/my-destination, it should redirect to /my-destination.

Proposed resolution

Remove all calls to exit and $response->send(); in the codebase, returning just the response object and instead handle the metadata bubbling context properly.

Remaining tasks

Provide issue fork/patch.

User interface changes

N/A

API changes

N/A

πŸ› Bug report
Status

Active

Version

5.0

Component

Code

Created by

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

Production build 0.71.5 2024