 cc6824fd7c
			
		
	
	cc6824fd7c
	
	
	
		
			
			* core: bump django from 4.1.7 to 4.2 (#5151) * core: bump django from 4.1.7 to 4.2 Bumps [django](https://github.com/django/django) from 4.1.7 to 4.2. - [Release notes](https://github.com/django/django/releases) - [Commits](https://github.com/django/django/compare/4.1.7...4.2) --- updated-dependencies: - dependency-name: django dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * upgrade to psycopg3, use custom engine for prometheus metrics See https://github.com/korfuri/django-prometheus/issues/350 Signed-off-by: Jens Langhammer <jens@goauthentik.io> * make scripts use pscopg3 Signed-off-by: Jens Langhammer <jens@goauthentik.io> --------- Signed-off-by: dependabot[bot] <support@github.com> Signed-off-by: Jens Langhammer <jens@goauthentik.io> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Jens Langhammer <jens@goauthentik.io> Signed-off-by: Jens Langhammer <jens@goauthentik.io> * start changelog Signed-off-by: Jens Langhammer <jens@goauthentik.io> * initial postgres upgrade guide Signed-off-by: Jens Langhammer <jens@goauthentik.io> * Apply suggestions from code review Co-authored-by: Tana M Berry <tanamarieberry@yahoo.com> Signed-off-by: Jens L. <jens@beryju.org> Signed-off-by: Jens Langhammer <jens@goauthentik.io> * update header Signed-off-by: Jens Langhammer <jens@goauthentik.io> --------- Signed-off-by: dependabot[bot] <support@github.com> Signed-off-by: Jens Langhammer <jens@goauthentik.io> Signed-off-by: Jens L. <jens@beryju.org> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Tana M Berry <tanamarieberry@yahoo.com>
		
			
				
	
	
		
			63 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env python
 | |
| """This file needs to be run from the root of the project to correctly
 | |
| import authentik. This is done by the dockerfile."""
 | |
| from sys import exit as sysexit
 | |
| from time import sleep
 | |
| from urllib.parse import quote_plus
 | |
| 
 | |
| from psycopg import OperationalError, connect
 | |
| from redis import Redis
 | |
| from redis.exceptions import RedisError
 | |
| 
 | |
| from authentik.lib.config import CONFIG
 | |
| 
 | |
| CONFIG.log("info", "Starting authentik bootstrap")
 | |
| 
 | |
| # Sanity check, ensure SECRET_KEY is set before we even check for database connectivity
 | |
| if CONFIG.get("secret_key") is None or len(CONFIG.get("secret_key")) == 0:
 | |
|     CONFIG.log("info", "----------------------------------------------------------------------")
 | |
|     CONFIG.log("info", "Secret key missing, check https://goauthentik.io/docs/installation/.")
 | |
|     CONFIG.log("info", "----------------------------------------------------------------------")
 | |
|     sysexit(1)
 | |
| 
 | |
| 
 | |
| while True:
 | |
|     try:
 | |
|         conn = connect(
 | |
|             dbname=CONFIG.get("postgresql.name"),
 | |
|             user=CONFIG.get("postgresql.user"),
 | |
|             password=CONFIG.get("postgresql.password"),
 | |
|             host=CONFIG.get("postgresql.host"),
 | |
|             port=CONFIG.get_int("postgresql.port"),
 | |
|             sslmode=CONFIG.get("postgresql.sslmode"),
 | |
|             sslrootcert=CONFIG.get("postgresql.sslrootcert"),
 | |
|             sslcert=CONFIG.get("postgresql.sslcert"),
 | |
|             sslkey=CONFIG.get("postgresql.sslkey"),
 | |
|         )
 | |
|         conn.cursor()
 | |
|         break
 | |
|     except OperationalError as exc:
 | |
|         sleep(1)
 | |
|         CONFIG.log("info", f"PostgreSQL connection failed, retrying... ({exc})")
 | |
| CONFIG.log("info", "PostgreSQL connection successful")
 | |
| 
 | |
| REDIS_PROTOCOL_PREFIX = "redis://"
 | |
| if CONFIG.get_bool("redis.tls", False):
 | |
|     REDIS_PROTOCOL_PREFIX = "rediss://"
 | |
| REDIS_URL = (
 | |
|     f"{REDIS_PROTOCOL_PREFIX}:"
 | |
|     f"{quote_plus(CONFIG.get('redis.password'))}@{quote_plus(CONFIG.get('redis.host'))}:"
 | |
|     f"{CONFIG.get_int('redis.port')}/{CONFIG.get('redis.db')}"
 | |
| )
 | |
| while True:
 | |
|     try:
 | |
|         redis = Redis.from_url(REDIS_URL)
 | |
|         redis.ping()
 | |
|         break
 | |
|     except RedisError as exc:
 | |
|         sleep(1)
 | |
|         CONFIG.log("info", f"Redis Connection failed, retrying... ({exc})", redis_url=REDIS_URL)
 | |
| CONFIG.log("info", "Redis Connection successful")
 | |
| 
 | |
| CONFIG.log("info", "Finished authentik bootstrap")
 |