Remove support for OAUTH_REDIRECT_AT_SIGN_IN (#17287)
Fixes #15959 Introduced in #6540, OAUTH_REDIRECT_AT_SIGN_IN allowed skipping the log-in form to instead redirect to the external OmniAuth login provider. However, it did not prevent the log-in form on /about introduced by #10232 from appearing, and completely broke with the introduction of #15228. As I restoring that previous log-in flow without introducing a security vulnerability may require extensive care and knowledge of how OmniAuth works, this commit removes support for OAUTH_REDIRECT_AT_SIGN_IN instead for the time being.
This commit is contained in:
		
							parent
							
								
									8a07ecd377
								
							
						
					
					
						commit
						cfa583fa71
					
				| @ -202,10 +202,6 @@ SMTP_FROM_ADDRESS=notifications@${APP_NAME}.nanoapp.io | |||||||
| # Name of the pam service used for checking if an user can register (pam "account" section is evaluated) (nil (disabled) by default) | # Name of the pam service used for checking if an user can register (pam "account" section is evaluated) (nil (disabled) by default) | ||||||
| # PAM_CONTROLLED_SERVICE=rpam | # PAM_CONTROLLED_SERVICE=rpam | ||||||
| 
 | 
 | ||||||
| # Global OAuth settings (optional) : |  | ||||||
| # If you have only one strategy, you may want to enable this |  | ||||||
| # OAUTH_REDIRECT_AT_SIGN_IN=true |  | ||||||
| 
 |  | ||||||
| # Optional CAS authentication (cf. omniauth-cas) : | # Optional CAS authentication (cf. omniauth-cas) : | ||||||
| # CAS_ENABLED=true | # CAS_ENABLED=true | ||||||
| # CAS_URL=https://sso.myserver.com/ | # CAS_URL=https://sso.myserver.com/ | ||||||
|  | |||||||
| @ -13,14 +13,6 @@ class Auth::SessionsController < Devise::SessionsController | |||||||
|   before_action :set_instance_presenter, only: [:new] |   before_action :set_instance_presenter, only: [:new] | ||||||
|   before_action :set_body_classes |   before_action :set_body_classes | ||||||
| 
 | 
 | ||||||
|   def new |  | ||||||
|     Devise.omniauth_configs.each do |provider, config| |  | ||||||
|       return redirect_to(omniauth_authorize_path(resource_name, provider)) if config.strategy.redirect_at_sign_in |  | ||||||
|     end |  | ||||||
| 
 |  | ||||||
|     super |  | ||||||
|   end |  | ||||||
| 
 |  | ||||||
|   def create |   def create | ||||||
|     super do |resource| |     super do |resource| | ||||||
|       # We only need to call this if this hasn't already been |       # We only need to call this if this hasn't already been | ||||||
| @ -87,14 +79,6 @@ class Auth::SessionsController < Devise::SessionsController | |||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   def after_sign_out_path_for(_resource_or_scope) |  | ||||||
|     Devise.omniauth_configs.each_value do |config| |  | ||||||
|       return root_path if config.strategy.redirect_at_sign_in |  | ||||||
|     end |  | ||||||
| 
 |  | ||||||
|     super |  | ||||||
|   end |  | ||||||
| 
 |  | ||||||
|   def require_no_authentication |   def require_no_authentication | ||||||
|     super |     super | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -5,7 +5,6 @@ end | |||||||
| Devise.setup do |config| | Devise.setup do |config| | ||||||
|   # Devise omniauth strategies |   # Devise omniauth strategies | ||||||
|   options = {} |   options = {} | ||||||
|   options[:redirect_at_sign_in] = ENV['OAUTH_REDIRECT_AT_SIGN_IN'] == 'true' |  | ||||||
| 
 | 
 | ||||||
|   # CAS strategy |   # CAS strategy | ||||||
|   if ENV['CAS_ENABLED'] == 'true' |   if ENV['CAS_ENABLED'] == 'true' | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user