providers/proxy: fix URL path getting lost when partial URL is given to rd= (cherry-pick #11354) (#11355)
providers/proxy: fix URL path getting lost when partial URL is given to rd= (#11354) * providers/proxy: fix URL path getting lost when partial URL is given to rd= * better fallback + tests --------- Signed-off-by: Jens Langhammer <jens@goauthentik.io> Co-authored-by: Jens L. <jens@goauthentik.io>
This commit is contained in:
		![98988430+gcp-cherry-pick-bot[bot]@users.noreply.github.com](/assets/img/avatar_default.png) gcp-cherry-pick-bot[bot]
					gcp-cherry-pick-bot[bot]
				
			
				
					committed by
					
						 GitHub
						GitHub
					
				
			
			
				
	
			
			
			 GitHub
						GitHub
					
				
			
						parent
						
							ee04f39e28
						
					
				
				
					commit
					3a2ed11821
				
			| @ -15,36 +15,6 @@ const ( | ||||
| 	LogoutSignature   = "X-authentik-logout" | ||||
| ) | ||||
|  | ||||
| func (a *Application) checkRedirectParam(r *http.Request) (string, bool) { | ||||
| 	rd := r.URL.Query().Get(redirectParam) | ||||
| 	if rd == "" { | ||||
| 		return "", false | ||||
| 	} | ||||
| 	u, err := url.Parse(rd) | ||||
| 	if err != nil { | ||||
| 		a.log.WithError(err).Warning("Failed to parse redirect URL") | ||||
| 		return "", false | ||||
| 	} | ||||
| 	// Check to make sure we only redirect to allowed places | ||||
| 	if a.Mode() == api.PROXYMODE_PROXY || a.Mode() == api.PROXYMODE_FORWARD_SINGLE { | ||||
| 		ext, err := url.Parse(a.proxyConfig.ExternalHost) | ||||
| 		if err != nil { | ||||
| 			return "", false | ||||
| 		} | ||||
| 		ext.Scheme = "" | ||||
| 		if !strings.Contains(u.String(), ext.String()) { | ||||
| 			a.log.WithField("url", u.String()).WithField("ext", ext.String()).Warning("redirect URI did not contain external host") | ||||
| 			return "", false | ||||
| 		} | ||||
| 	} else { | ||||
| 		if !strings.HasSuffix(u.Host, *a.proxyConfig.CookieDomain) { | ||||
| 			a.log.WithField("host", u.Host).WithField("dom", *a.proxyConfig.CookieDomain).Warning("redirect URI Host was not included in cookie domain") | ||||
| 			return "", false | ||||
| 		} | ||||
| 	} | ||||
| 	return u.String(), true | ||||
| } | ||||
|  | ||||
| func (a *Application) handleAuthStart(rw http.ResponseWriter, r *http.Request, fwd string) { | ||||
| 	state, err := a.createState(r, fwd) | ||||
| 	if err != nil { | ||||
|  | ||||
		Reference in New Issue
	
	Block a user