 f482937474
			
		
	
	f482937474
	
	
	
		
			
			* providers/proxy: fix handling of AUTHENTIK_HOST_BROWSER (#9622/#4688/#6476) * chore: fix tests
		
			
				
	
	
		
			89 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package application
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| 	"goauthentik.io/api/v3"
 | |
| 	"goauthentik.io/internal/config"
 | |
| )
 | |
| 
 | |
| func TestEndpointDefault(t *testing.T) {
 | |
| 	pc := api.ProxyOutpostConfig{
 | |
| 		OidcConfiguration: api.OpenIDConnectConfiguration{
 | |
| 			AuthorizationEndpoint: "https://test.goauthentik.io/application/o/authorize/",
 | |
| 			EndSessionEndpoint:    "https://test.goauthentik.io/application/o/test-app/end-session/",
 | |
| 			IntrospectionEndpoint: "https://test.goauthentik.io/application/o/introspect/",
 | |
| 			Issuer:                "https://test.goauthentik.io/application/o/test-app/",
 | |
| 			JwksUri:               "https://test.goauthentik.io/application/o/test-app/jwks/",
 | |
| 			TokenEndpoint:         "https://test.goauthentik.io/application/o/token/",
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	ep := GetOIDCEndpoint(pc, "https://authentik-host.test.goauthentik.io", false)
 | |
| 	// Standard outpost, non embedded
 | |
| 	// All URLs should use the host that they get from the config
 | |
| 	assert.Equal(t, "https://test.goauthentik.io/application/o/authorize/", ep.AuthURL)
 | |
| 	assert.Equal(t, "https://test.goauthentik.io/application/o/token/", ep.TokenURL)
 | |
| 	assert.Equal(t, "https://test.goauthentik.io/application/o/test-app/", ep.Issuer)
 | |
| 	assert.Equal(t, "https://test.goauthentik.io/application/o/test-app/jwks/", ep.JwksUri)
 | |
| 	assert.Equal(t, "https://test.goauthentik.io/application/o/test-app/end-session/", ep.EndSessionEndpoint)
 | |
| 	assert.Equal(t, "https://test.goauthentik.io/application/o/introspect/", ep.TokenIntrospection)
 | |
| }
 | |
| 
 | |
| func TestEndpointAuthentikHostBrowser(t *testing.T) {
 | |
| 	c := config.Get()
 | |
| 	c.AuthentikHostBrowser = "https://browser.test.goauthentik.io"
 | |
| 	defer func() {
 | |
| 		c.AuthentikHostBrowser = ""
 | |
| 	}()
 | |
| 	pc := api.ProxyOutpostConfig{
 | |
| 		OidcConfiguration: api.OpenIDConnectConfiguration{
 | |
| 			AuthorizationEndpoint: "https://test.goauthentik.io/application/o/authorize/",
 | |
| 			EndSessionEndpoint:    "https://test.goauthentik.io/application/o/test-app/end-session/",
 | |
| 			IntrospectionEndpoint: "https://test.goauthentik.io/application/o/introspect/",
 | |
| 			Issuer:                "https://test.goauthentik.io/application/o/test-app/",
 | |
| 			JwksUri:               "https://test.goauthentik.io/application/o/test-app/jwks/",
 | |
| 			TokenEndpoint:         "https://test.goauthentik.io/application/o/token/",
 | |
| 			UserinfoEndpoint:      "https://test.goauthentik.io/application/o/userinfo/",
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	ep := GetOIDCEndpoint(pc, "https://authentik-host.test.goauthentik.io", false)
 | |
| 	// Standard outpost, with AUTHENTIK_HOST_BROWSER set
 | |
| 	// Only the authorize/end session URLs should be changed
 | |
| 	assert.Equal(t, "https://browser.test.goauthentik.io/application/o/authorize/", ep.AuthURL)
 | |
| 	assert.Equal(t, "https://browser.test.goauthentik.io/application/o/test-app/end-session/", ep.EndSessionEndpoint)
 | |
| 	assert.Equal(t, "https://test.goauthentik.io/application/o/token/", ep.TokenURL)
 | |
| 	assert.Equal(t, "https://browser.test.goauthentik.io/application/o/test-app/", ep.Issuer)
 | |
| 	assert.Equal(t, "https://test.goauthentik.io/application/o/test-app/jwks/", ep.JwksUri)
 | |
| 	assert.Equal(t, "https://test.goauthentik.io/application/o/introspect/", ep.TokenIntrospection)
 | |
| }
 | |
| 
 | |
| func TestEndpointEmbedded(t *testing.T) {
 | |
| 	pc := api.ProxyOutpostConfig{
 | |
| 		OidcConfiguration: api.OpenIDConnectConfiguration{
 | |
| 			AuthorizationEndpoint: "https://test.goauthentik.io/application/o/authorize/",
 | |
| 			EndSessionEndpoint:    "https://test.goauthentik.io/application/o/test-app/end-session/",
 | |
| 			IntrospectionEndpoint: "https://test.goauthentik.io/application/o/introspect/",
 | |
| 			Issuer:                "https://test.goauthentik.io/application/o/test-app/",
 | |
| 			JwksUri:               "https://test.goauthentik.io/application/o/test-app/jwks/",
 | |
| 			TokenEndpoint:         "https://test.goauthentik.io/application/o/token/",
 | |
| 			UserinfoEndpoint:      "https://test.goauthentik.io/application/o/userinfo/",
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	ep := GetOIDCEndpoint(pc, "https://authentik-host.test.goauthentik.io", true)
 | |
| 	// Embedded outpost
 | |
| 	// Browser URLs should use the config of "authentik_host", everything else can use what's
 | |
| 	// received from the API endpoint
 | |
| 	// Token URL is an exception since it's sent via a special HTTP transport that overrides the
 | |
| 	// HTTP Host header, to make sure it's the same value as the issuer
 | |
| 	assert.Equal(t, "https://authentik-host.test.goauthentik.io/application/o/authorize/", ep.AuthURL)
 | |
| 	assert.Equal(t, "https://authentik-host.test.goauthentik.io/application/o/test-app/", ep.Issuer)
 | |
| 	assert.Equal(t, "https://test.goauthentik.io/application/o/token/", ep.TokenURL)
 | |
| 	assert.Equal(t, "https://authentik-host.test.goauthentik.io/application/o/test-app/jwks/", ep.JwksUri)
 | |
| 	assert.Equal(t, "https://authentik-host.test.goauthentik.io/application/o/test-app/end-session/", ep.EndSessionEndpoint)
 | |
| 	assert.Equal(t, "https://test.goauthentik.io/application/o/introspect/", ep.TokenIntrospection)
 | |
| }
 |