 1b81973358
			
		
	
	1b81973358
	
	
	
		
			
			* outposts/proxy: Fix invalid redirect on external hosts containing path components Signed-off-by: Max <github@germancoding.com> * outposts/proxy: Fix test for changed redirect logic Signed-off-by: Max <github@germancoding.com> --------- Signed-off-by: Max <github@germancoding.com>
		
			
				
	
	
		
			123 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			123 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package application
 | |
| 
 | |
| import (
 | |
| 	"net/http"
 | |
| 	"net/http/httptest"
 | |
| 	"net/url"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/google/uuid"
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| 	"goauthentik.io/internal/outpost/proxyv2/constants"
 | |
| )
 | |
| 
 | |
| func TestProxy_ModifyRequest(t *testing.T) {
 | |
| 	a := newTestApplication()
 | |
| 	req, _ := http.NewRequest("GET", "http://frontend/foo", nil)
 | |
| 	u, err := url.Parse("http://backend:8012")
 | |
| 	if err != nil {
 | |
| 		panic(err)
 | |
| 	}
 | |
| 	a.proxyModifyRequest(u)(req)
 | |
| 
 | |
| 	assert.Equal(t, "frontend", req.Header.Get("X-Forwarded-Host"))
 | |
| 	assert.Equal(t, "/foo", req.URL.Path)
 | |
| 	assert.Equal(t, "backend:8012", req.URL.Host)
 | |
| 	assert.Equal(t, "frontend", req.Host)
 | |
| }
 | |
| 
 | |
| func TestProxy_Redirect(t *testing.T) {
 | |
| 	a := newTestApplication()
 | |
| 	_ = a.configureProxy()
 | |
| 	req, _ := http.NewRequest("GET", "https://ext.t.goauthentik.io/foo", nil)
 | |
| 	rr := httptest.NewRecorder()
 | |
| 
 | |
| 	a.mux.ServeHTTP(rr, req)
 | |
| 
 | |
| 	assert.Equal(t, http.StatusFound, rr.Code)
 | |
| 	loc, _ := rr.Result().Location()
 | |
| 	assert.Equal(
 | |
| 		t,
 | |
| 		"https://ext.t.goauthentik.io/outpost.goauthentik.io/start?rd=https%3A%2F%2Fext.t.goauthentik.io%2Ffoo",
 | |
| 		loc.String(),
 | |
| 	)
 | |
| }
 | |
| 
 | |
| func TestProxy_Redirect_Subdirectory(t *testing.T) {
 | |
| 	a := newTestApplication()
 | |
| 	a.proxyConfig.ExternalHost = a.proxyConfig.ExternalHost + "/subdir"
 | |
| 	_ = a.configureProxy()
 | |
| 	req, _ := http.NewRequest("GET", "https://ext.t.goauthentik.io/foo", nil)
 | |
| 	rr := httptest.NewRecorder()
 | |
| 
 | |
| 	a.mux.ServeHTTP(rr, req)
 | |
| 
 | |
| 	assert.Equal(t, http.StatusFound, rr.Code)
 | |
| 	loc, _ := rr.Result().Location()
 | |
| 	assert.Equal(
 | |
| 		t,
 | |
| 		"https://ext.t.goauthentik.io/subdir/outpost.goauthentik.io/start?rd=https%3A%2F%2Fext.t.goauthentik.io%2Fsubdir%2Ffoo",
 | |
| 		loc.String(),
 | |
| 	)
 | |
| }
 | |
| 
 | |
| func TestProxy_ModifyRequest_Claims(t *testing.T) {
 | |
| 	a := newTestApplication()
 | |
| 	req, _ := http.NewRequest("GET", "http://frontend/foo", nil)
 | |
| 	u, err := url.Parse("http://backend:8012")
 | |
| 	if err != nil {
 | |
| 		panic(err)
 | |
| 	}
 | |
| 	rr := httptest.NewRecorder()
 | |
| 
 | |
| 	s, _ := a.sessions.Get(req, a.SessionName())
 | |
| 	s.ID = uuid.New().String()
 | |
| 	s.Options.MaxAge = 86400
 | |
| 	s.Values[constants.SessionClaims] = Claims{
 | |
| 		Sub: "foo",
 | |
| 		Proxy: &ProxyClaims{
 | |
| 			BackendOverride: "http://other-backend:8123",
 | |
| 		},
 | |
| 	}
 | |
| 	err = a.sessions.Save(req, rr, s)
 | |
| 	if err != nil {
 | |
| 		panic(err)
 | |
| 	}
 | |
| 
 | |
| 	a.proxyModifyRequest(u)(req)
 | |
| 
 | |
| 	assert.Equal(t, "/foo", req.URL.Path)
 | |
| 	assert.Equal(t, "other-backend:8123", req.URL.Host)
 | |
| 	assert.Equal(t, "frontend", req.Host)
 | |
| }
 | |
| 
 | |
| func TestProxy_ModifyRequest_Claims_Invalid(t *testing.T) {
 | |
| 	a := newTestApplication()
 | |
| 	req, _ := http.NewRequest("GET", "http://frontend/foo", nil)
 | |
| 	u, err := url.Parse("http://backend:8012")
 | |
| 	if err != nil {
 | |
| 		panic(err)
 | |
| 	}
 | |
| 	rr := httptest.NewRecorder()
 | |
| 
 | |
| 	s, _ := a.sessions.Get(req, a.SessionName())
 | |
| 	s.ID = uuid.New().String()
 | |
| 	s.Options.MaxAge = 86400
 | |
| 	s.Values[constants.SessionClaims] = Claims{
 | |
| 		Sub: "foo",
 | |
| 		Proxy: &ProxyClaims{
 | |
| 			BackendOverride: ":qewr",
 | |
| 		},
 | |
| 	}
 | |
| 	err = a.sessions.Save(req, rr, s)
 | |
| 	if err != nil {
 | |
| 		panic(err)
 | |
| 	}
 | |
| 
 | |
| 	a.proxyModifyRequest(u)(req)
 | |
| 
 | |
| 	assert.Equal(t, "/foo", req.URL.Path)
 | |
| 	assert.Equal(t, "backend:8012", req.URL.Host)
 | |
| 	assert.Equal(t, "frontend", req.Host)
 | |
| }
 |