* root: initial rename * web: rename custom element prefix * root: rename external functions with pb_ prefix * root: fix formatting * root: replace domain with goauthentik.io * proxy: update path * root: rename remaining prefixes * flows: rename file extension * root: pbadmin -> akadmin * docs: fix image filenames * lifecycle: ignore migration files * ci: copy default config from current source before loading last tagged * *: new sentry dsn * tests: fix missing python3.9-dev package * root: add additional migrations for service accounts created by outposts * core: mark system-created service accounts with attribute * policies/expression: fix pb_ replacement not working * web: fix last linting errors, add lit-analyse * policies/expressions: fix lint errors * web: fix sidebar display on screens where not all items fit * proxy: attempt to fix proxy pipeline * proxy: use go env GOPATH to get gopath * lib: fix user_default naming inconsistency * docs: add upgrade docs * docs: update screenshots to use authentik * admin: fix create button on empty-state of outpost * web: fix modal submit not refreshing SiteShell and Table * web: fix height of app-card and height of generic icon * web: fix rendering of subtext * admin: fix version check error not being caught * web: fix worker count not being shown * docs: update screenshots * root: new icon * web: fix lint error * admin: fix linting error * root: migrate coverage config to pyproject
		
			
				
	
	
		
			60 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package cmd
 | 
						|
 | 
						|
import (
 | 
						|
	"fmt"
 | 
						|
	"math/rand"
 | 
						|
	"net/url"
 | 
						|
	"os"
 | 
						|
	"os/signal"
 | 
						|
	"time"
 | 
						|
 | 
						|
	"github.com/BeryJu/authentik/proxy/pkg/server"
 | 
						|
)
 | 
						|
 | 
						|
const helpMessage = `authentik proxy
 | 
						|
 | 
						|
Required environment variables:
 | 
						|
 - AUTHENTIK_HOST: URL to connect to (format "http://authentik.company")
 | 
						|
 - AUTHENTIK_TOKEN: Token to authenticate with
 | 
						|
 - AUTHENTIK_INSECURE: Skip SSL Certificate verification`
 | 
						|
 | 
						|
// RunServer main entrypoint, runs the full server
 | 
						|
func RunServer() {
 | 
						|
	pbURL, found := os.LookupEnv("AUTHENTIK_HOST")
 | 
						|
	if !found {
 | 
						|
		fmt.Println("env AUTHENTIK_HOST not set!")
 | 
						|
		fmt.Println(helpMessage)
 | 
						|
		os.Exit(1)
 | 
						|
	}
 | 
						|
	pbToken, found := os.LookupEnv("AUTHENTIK_TOKEN")
 | 
						|
	if !found {
 | 
						|
		fmt.Println("env AUTHENTIK_TOKEN not set!")
 | 
						|
		fmt.Println(helpMessage)
 | 
						|
		os.Exit(1)
 | 
						|
	}
 | 
						|
 | 
						|
	pbURLActual, err := url.Parse(pbURL)
 | 
						|
	if err != nil {
 | 
						|
		fmt.Println(err)
 | 
						|
		fmt.Println(helpMessage)
 | 
						|
		os.Exit(1)
 | 
						|
	}
 | 
						|
 | 
						|
	rand.Seed(time.Now().UnixNano())
 | 
						|
 | 
						|
	ac := server.NewAPIController(*pbURLActual, pbToken)
 | 
						|
 | 
						|
	interrupt := make(chan os.Signal, 1)
 | 
						|
	signal.Notify(interrupt, os.Interrupt)
 | 
						|
 | 
						|
	ac.Start()
 | 
						|
 | 
						|
	for {
 | 
						|
		select {
 | 
						|
		case <-interrupt:
 | 
						|
			ac.Shutdown()
 | 
						|
			os.Exit(0)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 |