Compare commits
	
		
			26 Commits
		
	
	
		
			3.2.4+2023
			...
			custom-css
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| c39b6ad25a | |||
| 1ffb62d74a | |||
| 5086df24fb | |||
| e07d57718a | |||
| 553b97ba21 | |||
| 75f42db773 | |||
| d115d5ce38 | |||
| 68eda3e2d7 | |||
| 91756202c2 | |||
| bf2397b0e9 | |||
| c3b01c1d27 | |||
| 8d32814219 | |||
| 78cfd95198 | |||
| 4593eb6340 | |||
| 0419ed279d | |||
| abb49e7019 | |||
| 74f654c192 | |||
| 7a4daaf475 | |||
| b7605f6a87 | |||
| 01ca1b4d5c | |||
| 287426b06a | |||
| b311cadc4c | |||
| d01c539c4f | |||
| 427644df38 | |||
| f4172f2a64 | |||
| 126b50d4bd | 
@ -23,7 +23,7 @@ steps:
 | 
			
		||||
      FLOW_INVALIDATION_VERSION: v1
 | 
			
		||||
      FLOW_RECOVERY_VERSION: v1
 | 
			
		||||
      FLOW_TRANSLATION_VERSION: v1
 | 
			
		||||
      SYSTEM_TENANT_VERSION: v1
 | 
			
		||||
      SYSTEM_BRAND_VERSION: v1
 | 
			
		||||
      NEXTCLOUD_CONFIG_VERSION: v1
 | 
			
		||||
      SECRET_SECRET_KEY_VERSION: v1
 | 
			
		||||
      SECRET_DB_PASSWORD_VERSION: v1
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										30
									
								
								.env.sample
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								.env.sample
									
									
									
									
									
								
							@ -1,5 +1,5 @@
 | 
			
		||||
TYPE=authentik
 | 
			
		||||
TIMEOUT=300
 | 
			
		||||
TIMEOUT=900
 | 
			
		||||
ENABLE_AUTO_UPDATE=true
 | 
			
		||||
# POST_DEPLOY_CMDS="worker set_admin_pass|worker apply_blueprints|worker add_applications"
 | 
			
		||||
LETS_ENCRYPT_ENV=production
 | 
			
		||||
@ -34,7 +34,6 @@ SECRET_ADMIN_PASS_VERSION=v1
 | 
			
		||||
SECRET_EMAIL_PASS_VERSION=v1
 | 
			
		||||
 | 
			
		||||
# X_FRAME_OPTIONS_ALLOW_FROM=dashboard.example.org
 | 
			
		||||
AUTHENTIK_COLOR_BACKGROUND_LIGHT=#1c1e21
 | 
			
		||||
 | 
			
		||||
## FLOW OPTIONS
 | 
			
		||||
# WELCOME_MESSAGE="Welcome to Authentik"
 | 
			
		||||
@ -47,6 +46,12 @@ COPY_ASSETS="flow_background.jpg|app:/web/dist/assets/images/"
 | 
			
		||||
COPY_ASSETS="$COPY_ASSETS icon_left_brand.svg|app:/web/dist/assets/icons/"
 | 
			
		||||
COPY_ASSETS="$COPY_ASSETS icon.png|app:/web/dist/assets/icons/"
 | 
			
		||||
 | 
			
		||||
# Default CSS customisation, just background colour
 | 
			
		||||
COMPOSE_FILE="$COMPOSE_FILE:compose.css.yml"
 | 
			
		||||
AUTHENTIK_COLOR_BACKGROUND_LIGHT=#1c1e21
 | 
			
		||||
# Custommise the entire custom CSS file
 | 
			
		||||
#COMPOSE_FILE="$COMPOSE_FILE:compose.css.yml"
 | 
			
		||||
 | 
			
		||||
# COMPOSE_FILE="$COMPOSE_FILE:compose.nextcloud.yml"
 | 
			
		||||
# NEXTCLOUD_DOMAIN=nextcloud.example.com
 | 
			
		||||
# SECRET_NEXTCLOUD_ID_VERSION=v1
 | 
			
		||||
@ -78,13 +83,30 @@ COPY_ASSETS="$COPY_ASSETS icon.png|app:/web/dist/assets/icons/"
 | 
			
		||||
# SECRET_VIKUNJA_SECRET_VERSION=v1
 | 
			
		||||
# APP_ICONS="$APP_ICONS vikunja:~/.abra/recipes/authentik/icons/vikunja.svg"
 | 
			
		||||
 | 
			
		||||
# COMPOSE_FILE="$COMPOSE_FILE:compose.outline.yml"
 | 
			
		||||
# OUTLINE_DOMAIN=outline.example.com
 | 
			
		||||
# SECRET_OUTLINE_ID_VERSION=v1
 | 
			
		||||
# SECRET_OUTLINE_SECRET_VERSION=v1
 | 
			
		||||
# APP_ICONS="$APP_ICONS outline:~/.abra/recipes/authentik/icons/outline.png"
 | 
			
		||||
 | 
			
		||||
# COMPOSE_FILE="$COMPOSE_FILE:compose.monitoring.yml"
 | 
			
		||||
# MONITORING_DOMAIN=monitoring.example.com
 | 
			
		||||
# SECRET_MONITORING_ID_VERSION=v1
 | 
			
		||||
# SECRET_MONITORING_SECRET_VERSION=v1
 | 
			
		||||
# APP_ICONS="$APP_ICONS monitoring:~/.abra/recipes/authentik/icons/monitoring.png"
 | 
			
		||||
 | 
			
		||||
# APPLICATIONS='{"Calendar": "https://nextcloud.example.com/apps/calendar/", "BBB": "https://nextcloud.example.com/apps/bbb/", "Rallly":"https://rallly.example.cloud/"}'
 | 
			
		||||
# COMPOSE_FILE="$COMPOSE_FILE:compose.rallly.yml"
 | 
			
		||||
# RALLLY_DOMAIN=rallly.example.com
 | 
			
		||||
# SECRET_RALLLY_ID_VERSION=v1
 | 
			
		||||
# SECRET_RALLLY_SECRET_VERSION=v1
 | 
			
		||||
# APP_ICONS="$APP_ICONS rallly:~/.abra/recipes/authentik/icons/rallly.png"
 | 
			
		||||
 | 
			
		||||
# COMPOSE_FILE="$COMPOSE_FILE:compose.hedgedoc.yml"
 | 
			
		||||
# HEDGEDOC_DOMAIN=hedgedoc.example.com
 | 
			
		||||
# SECRET_HEDGEDOC_ID_VERSION=v1
 | 
			
		||||
# SECRET_HEDGEDOC_SECRET_VERSION=v1
 | 
			
		||||
# APP_ICONS="$APP_ICONS hedgedoc:~/.abra/recipes/authentik/icons/hedgedoc.png"
 | 
			
		||||
 | 
			
		||||
# APPLICATIONS='{"Calendar": "https://nextcloud.example.com/apps/calendar/", "BBB": "https://nextcloud.example.com/apps/bbb/"}'
 | 
			
		||||
# APP_ICONS="$APP_ICONS Calendar:~/.abra/recipes/authentik/icons/calendar.svg"
 | 
			
		||||
# APP_ICONS="$APP_ICONS Rallly:~/.abra/recipes/authentik/icons/rallly.png"
 | 
			
		||||
# APP_ICONS="$APP_ICONS BBB:~/.abra/recipes/authentik/icons/bbb.jpg"
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										10
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								README.md
									
									
									
									
									
								
							@ -167,9 +167,9 @@ The `abra.sh` function `apply_blueprints` needs to be executed to deactivate the
 | 
			
		||||
    - Default - Source enrollment flow
 | 
			
		||||
        - OVERWRITE:
 | 
			
		||||
            - `default-source-enrollment-field-username`
 | 
			
		||||
- Custom System Tenant
 | 
			
		||||
    - Default - Tenant
 | 
			
		||||
        - APPEND: `authentik_tenants.tenant  domain: authentik-default`
 | 
			
		||||
- Custom System Brand
 | 
			
		||||
    - Default - Brand
 | 
			
		||||
        - APPEND: `authentik_brands.brand  domain: authentik-default`
 | 
			
		||||
    - Recovery with email verification
 | 
			
		||||
        - USE:
 | 
			
		||||
            - `default-recovery-flow`
 | 
			
		||||
@ -177,8 +177,8 @@ The `abra.sh` function `apply_blueprints` needs to be executed to deactivate the
 | 
			
		||||
 | 
			
		||||
### Blueprint Dependency Execution Order
 | 
			
		||||
 | 
			
		||||
5. Custom System Tenant
 | 
			
		||||
    - Default - Tenant
 | 
			
		||||
5. Custom System Brand
 | 
			
		||||
    - Default - Brand
 | 
			
		||||
    1. Recovery with email verification
 | 
			
		||||
        - Default - Authentication flow
 | 
			
		||||
            - Default - Password change flow
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										14
									
								
								abra.sh
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								abra.sh
									
									
									
									
									
								
							@ -1,16 +1,20 @@
 | 
			
		||||
export CUSTOM_CSS_VERSION=v2
 | 
			
		||||
export FLOW_AUTHENTICATION_VERSION=v3
 | 
			
		||||
export FLOW_INVITATION_VERSION=v1
 | 
			
		||||
export FLOW_AUTHENTICATION_VERSION=v4
 | 
			
		||||
export FLOW_INVITATION_VERSION=v2
 | 
			
		||||
export FLOW_INVALIDATION_VERSION=v2
 | 
			
		||||
export FLOW_RECOVERY_VERSION=v1
 | 
			
		||||
export FLOW_TRANSLATION_VERSION=v2
 | 
			
		||||
export SYSTEM_TENANT_VERSION=v2
 | 
			
		||||
export FLOW_TRANSLATION_VERSION=v3
 | 
			
		||||
export SYSTEM_BRAND_VERSION=v3
 | 
			
		||||
export NEXTCLOUD_CONFIG_VERSION=v1
 | 
			
		||||
export WORDPRESS_CONFIG_VERSION=v2
 | 
			
		||||
export MATRIX_CONFIG_VERSION=v1
 | 
			
		||||
export WEKAN_CONFIG_VERSION=v3
 | 
			
		||||
export VIKUNJA_CONFIG_VERSION=v1
 | 
			
		||||
export OUTLINE_CONFIG_VERSION=v2
 | 
			
		||||
export RALLLY_CONFIG_VERSION=v2
 | 
			
		||||
export HEDGEDOC_CONFIG_VERSION=v1
 | 
			
		||||
export MONITORING_CONFIG_VERSION=v1
 | 
			
		||||
export DB_ENTRYPOINT_VERSION=v1
 | 
			
		||||
 | 
			
		||||
customize() {
 | 
			
		||||
    if [ -z "$1" ]
 | 
			
		||||
@ -214,7 +218,7 @@ delete_flows = ['default-recovery-flow' , 'custom-authentication-flow' , 'invita
 | 
			
		||||
Flow.objects.filter(slug__in=delete_flows).delete()
 | 
			
		||||
Stage.objects.filter(flow=None).delete()
 | 
			
		||||
Prompt.objects.filter(promptstage=None).delete()
 | 
			
		||||
Tenant.objects.filter(default=True).delete()
 | 
			
		||||
Brand.objects.filter(default=True).delete()
 | 
			
		||||
""" 2>&1 | quieten
 | 
			
		||||
apply_blueprints
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										14
									
								
								compose.css.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								compose.css.yml
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,14 @@
 | 
			
		||||
---
 | 
			
		||||
version: '3.8'
 | 
			
		||||
 | 
			
		||||
services:
 | 
			
		||||
  app:
 | 
			
		||||
    configs: 
 | 
			
		||||
      - source: custom_css
 | 
			
		||||
        target: /web/dist/custom.css
 | 
			
		||||
 | 
			
		||||
configs:
 | 
			
		||||
  custom_css:
 | 
			
		||||
    name: ${STACK_NAME}_custom_css_${CUSTOM_CSS_VERSION}
 | 
			
		||||
    file: custom.css.tmpl
 | 
			
		||||
    template_driver: golang
 | 
			
		||||
							
								
								
									
										26
									
								
								compose.hedgedoc.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								compose.hedgedoc.yml
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,26 @@
 | 
			
		||||
version: "3.8"
 | 
			
		||||
services:
 | 
			
		||||
  worker:
 | 
			
		||||
    secrets:
 | 
			
		||||
      - hedgedoc_id
 | 
			
		||||
      - hedgedoc_secret
 | 
			
		||||
    environment:
 | 
			
		||||
      - HEDGEDOC_DOMAIN
 | 
			
		||||
    configs:
 | 
			
		||||
      - source: hedgedoc
 | 
			
		||||
        target: /blueprints/hedgedoc.yaml
 | 
			
		||||
 | 
			
		||||
secrets:
 | 
			
		||||
  hedgedoc_id:
 | 
			
		||||
    external: true
 | 
			
		||||
    name: ${STACK_NAME}_hedgedoc_id_${SECRET_HEDGEDOC_ID_VERSION}
 | 
			
		||||
  hedgedoc_secret:
 | 
			
		||||
    external: true
 | 
			
		||||
    name: ${STACK_NAME}_hedgedoc_secret_${SECRET_HEDGEDOC_SECRET_VERSION}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
configs:
 | 
			
		||||
  hedgedoc:
 | 
			
		||||
    name: ${STACK_NAME}_hedgedoc_${HEDGEDOC_CONFIG_VERSION}
 | 
			
		||||
    file: hedgedoc.yaml.tmpl
 | 
			
		||||
    template_driver: golang
 | 
			
		||||
							
								
								
									
										26
									
								
								compose.outline.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								compose.outline.yml
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,26 @@
 | 
			
		||||
version: "3.8"
 | 
			
		||||
services:
 | 
			
		||||
  worker:
 | 
			
		||||
    secrets:
 | 
			
		||||
      - outline_id
 | 
			
		||||
      - outline_secret
 | 
			
		||||
    environment:
 | 
			
		||||
      - OUTLINE_DOMAIN
 | 
			
		||||
    configs:
 | 
			
		||||
      - source: outline
 | 
			
		||||
        target: /blueprints/outline.yaml
 | 
			
		||||
 | 
			
		||||
secrets:
 | 
			
		||||
  outline_id:
 | 
			
		||||
    external: true
 | 
			
		||||
    name: ${STACK_NAME}_outline_id_${SECRET_OUTLINE_ID_VERSION}
 | 
			
		||||
  outline_secret:
 | 
			
		||||
    external: true
 | 
			
		||||
    name: ${STACK_NAME}_outline_secret_${SECRET_OUTLINE_SECRET_VERSION}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
configs:
 | 
			
		||||
  outline:
 | 
			
		||||
    name: ${STACK_NAME}_outline_${OUTLINE_CONFIG_VERSION}
 | 
			
		||||
    file: outline.yaml.tmpl
 | 
			
		||||
    template_driver: golang
 | 
			
		||||
							
								
								
									
										26
									
								
								compose.rallly.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								compose.rallly.yml
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,26 @@
 | 
			
		||||
version: "3.8"
 | 
			
		||||
services:
 | 
			
		||||
  worker:
 | 
			
		||||
    secrets:
 | 
			
		||||
      - rallly_id
 | 
			
		||||
      - rallly_secret
 | 
			
		||||
    environment:
 | 
			
		||||
      - RALLLY_DOMAIN
 | 
			
		||||
    configs:
 | 
			
		||||
      - source: rallly
 | 
			
		||||
        target: /blueprints/rallly.yaml
 | 
			
		||||
 | 
			
		||||
secrets:
 | 
			
		||||
  rallly_id:
 | 
			
		||||
    external: true
 | 
			
		||||
    name: ${STACK_NAME}_rallly_id_${SECRET_RALLLY_ID_VERSION}
 | 
			
		||||
  rallly_secret:
 | 
			
		||||
    external: true
 | 
			
		||||
    name: ${STACK_NAME}_rallly_secret_${SECRET_RALLLY_SECRET_VERSION}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
configs:
 | 
			
		||||
  rallly:
 | 
			
		||||
    name: ${STACK_NAME}_rallly_${RALLLY_CONFIG_VERSION}
 | 
			
		||||
    file: rallly.yaml.tmpl
 | 
			
		||||
    template_driver: golang
 | 
			
		||||
							
								
								
									
										45
									
								
								compose.yml
									
									
									
									
									
								
							
							
						
						
									
										45
									
								
								compose.yml
									
									
									
									
									
								
							@ -32,8 +32,11 @@ x-env: &env
 | 
			
		||||
version: '3.8'
 | 
			
		||||
services:
 | 
			
		||||
  app:
 | 
			
		||||
    image: ghcr.io/goauthentik/server:2023.6.1
 | 
			
		||||
    image: ghcr.io/goauthentik/server:2024.4.0
 | 
			
		||||
    command: server
 | 
			
		||||
    depends_on:
 | 
			
		||||
      - db
 | 
			
		||||
      - redis
 | 
			
		||||
    secrets:
 | 
			
		||||
      - db_password
 | 
			
		||||
      - admin_pass
 | 
			
		||||
@ -44,9 +47,6 @@ services:
 | 
			
		||||
      - media:/media
 | 
			
		||||
      - assets:/web/dist/assets
 | 
			
		||||
      - templates:/templates
 | 
			
		||||
    configs:
 | 
			
		||||
      - source: custom_css
 | 
			
		||||
        target: /web/dist/custom.css
 | 
			
		||||
    networks:
 | 
			
		||||
      - internal
 | 
			
		||||
      - proxy
 | 
			
		||||
@ -73,12 +73,15 @@ services:
 | 
			
		||||
        - "traefik.http.middlewares.${STACK_NAME}-redirect.headers.SSLHost=${DOMAIN}"
 | 
			
		||||
        - "traefik.http.middlewares.${STACK_NAME}-frameOptions.headers.customFrameOptionsValue=SAMEORIGIN"
 | 
			
		||||
        - "traefik.http.middlewares.${STACK_NAME}-frameOptions.headers.contentSecurityPolicy=frame-ancestors ${X_FRAME_OPTIONS_ALLOW_FROM}"
 | 
			
		||||
        - "coop-cloud.${STACK_NAME}.version=3.2.4+2023.6.1"
 | 
			
		||||
        - "coop-cloud.${STACK_NAME}.version=5.2.1+2024.4.0"
 | 
			
		||||
        - "coop-cloud.${STACK_NAME}.timeout=${TIMEOUT:-120}"
 | 
			
		||||
 | 
			
		||||
  worker:
 | 
			
		||||
    image: ghcr.io/goauthentik/server:2023.6.1
 | 
			
		||||
    image: ghcr.io/goauthentik/server:2024.4.0
 | 
			
		||||
    command: worker
 | 
			
		||||
    depends_on:
 | 
			
		||||
      - db
 | 
			
		||||
      - redis
 | 
			
		||||
    secrets:
 | 
			
		||||
      - db_password
 | 
			
		||||
      - admin_pass
 | 
			
		||||
@ -102,16 +105,22 @@ services:
 | 
			
		||||
        target: /blueprints/3_flow_translation.yaml
 | 
			
		||||
      - source: flow_invitation
 | 
			
		||||
        target: /blueprints/4_flow_invitation.yaml
 | 
			
		||||
      - source: system_tenant
 | 
			
		||||
        target: /blueprints/5_system_tenant.yaml
 | 
			
		||||
      - source: system_brand
 | 
			
		||||
        target: /blueprints/5_system_brand.yaml
 | 
			
		||||
      - source: flow_invalidation
 | 
			
		||||
        target: /blueprints/6_flow_invalidation.yaml
 | 
			
		||||
    environment: *env
 | 
			
		||||
 | 
			
		||||
  db:
 | 
			
		||||
    image: postgres:12.15-alpine
 | 
			
		||||
    image: postgres:15.5
 | 
			
		||||
    secrets:
 | 
			
		||||
      - db_password
 | 
			
		||||
    configs:
 | 
			
		||||
      - source: db_entrypoint
 | 
			
		||||
        target: /docker-entrypoint.sh
 | 
			
		||||
        mode: 0555
 | 
			
		||||
    entrypoint:
 | 
			
		||||
      /docker-entrypoint.sh
 | 
			
		||||
    volumes:
 | 
			
		||||
      - database:/var/lib/postgresql/data
 | 
			
		||||
    networks:
 | 
			
		||||
@ -134,11 +143,11 @@ services:
 | 
			
		||||
          backupbot.backup.path: "/var/lib/postgresql/data"
 | 
			
		||||
 | 
			
		||||
  redis:
 | 
			
		||||
    image:  redis:7.0.12-alpine
 | 
			
		||||
    image:  redis:7.2.4-alpine
 | 
			
		||||
    networks:
 | 
			
		||||
      - internal
 | 
			
		||||
    healthcheck:
 | 
			
		||||
      test: ["CMD", "redis-cli","ping"]
 | 
			
		||||
      test: ["CMD-SHELL", "redis-cli ping | grep PONG"]
 | 
			
		||||
      interval: 30s
 | 
			
		||||
      timeout: 10s
 | 
			
		||||
      retries: 10
 | 
			
		||||
@ -174,10 +183,6 @@ volumes:
 | 
			
		||||
  database:
 | 
			
		||||
 | 
			
		||||
configs:
 | 
			
		||||
  custom_css:
 | 
			
		||||
    name: ${STACK_NAME}_custom_css_${CUSTOM_CSS_VERSION}
 | 
			
		||||
    file: custom.css.tmpl
 | 
			
		||||
    template_driver: golang
 | 
			
		||||
  flow_authentication:
 | 
			
		||||
    name: ${STACK_NAME}_flow_authentication_${FLOW_AUTHENTICATION_VERSION}
 | 
			
		||||
    file: flow_authentication.yaml.tmpl
 | 
			
		||||
@ -198,7 +203,11 @@ configs:
 | 
			
		||||
    name: ${STACK_NAME}_flow_translation_${FLOW_TRANSLATION_VERSION}
 | 
			
		||||
    file: flow_translation.yaml.tmpl
 | 
			
		||||
    template_driver: golang
 | 
			
		||||
  system_tenant:
 | 
			
		||||
    name: ${STACK_NAME}_system_tenant_${SYSTEM_TENANT_VERSION}
 | 
			
		||||
    file: system_tenant.yaml.tmpl
 | 
			
		||||
  system_brand:
 | 
			
		||||
    name: ${STACK_NAME}_system_brand_${SYSTEM_BRAND_VERSION}
 | 
			
		||||
    file: system_brand.yaml.tmpl
 | 
			
		||||
    template_driver: golang
 | 
			
		||||
  db_entrypoint:
 | 
			
		||||
    name: ${STACK_NAME}_db_entrypoint_${DB_ENTRYPOINT_VERSION}
 | 
			
		||||
    file: entrypoint.postgres.sh.tmpl
 | 
			
		||||
    template_driver: golang
 | 
			
		||||
 | 
			
		||||
@ -384,7 +384,7 @@ entries:
 | 
			
		||||
    enabled: {{ if eq (env "LOGOUT_REDIRECT") "" }} false {{ else }} true {{ end }}
 | 
			
		||||
    timeout: 30
 | 
			
		||||
 | 
			
		||||
######## System Tenant ##########
 | 
			
		||||
######## System Brand ##########
 | 
			
		||||
- attrs:
 | 
			
		||||
    attributes:
 | 
			
		||||
      settings:
 | 
			
		||||
@ -401,5 +401,5 @@ entries:
 | 
			
		||||
    flow_user_settings: !Find [authentik_flows.flow, [slug, default-user-settings-flow]]
 | 
			
		||||
  identifiers:
 | 
			
		||||
    pk: 047cce25-aae2-4b02-9f96-078e155f803d
 | 
			
		||||
  id: system_tenant
 | 
			
		||||
  model: authentik_tenants.tenant
 | 
			
		||||
  id: system_brand
 | 
			
		||||
  model: authentik_brands.brand
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										45
									
								
								entrypoint.postgres.sh.tmpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								entrypoint.postgres.sh.tmpl
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,45 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
 | 
			
		||||
set -e
 | 
			
		||||
 | 
			
		||||
MIGRATION_MARKER=$PGDATA/migration_in_progress
 | 
			
		||||
OLDDATA=$PGDATA/old_data
 | 
			
		||||
NEWDATA=$PGDATA/new_data
 | 
			
		||||
 | 
			
		||||
if [ -e $MIGRATION_MARKER ]; then
 | 
			
		||||
  echo "FATAL: migration was started but did not complete in a previous run. manual recovery necessary"
 | 
			
		||||
  exit 1
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
if [ -f $PGDATA/PG_VERSION ]; then
 | 
			
		||||
  DATA_VERSION=$(cat $PGDATA/PG_VERSION)
 | 
			
		||||
 | 
			
		||||
  if [ -n "$DATA_VERSION" -a "$PG_MAJOR" != "$DATA_VERSION" ]; then
 | 
			
		||||
    echo "postgres data version $DATA_VERSION found, but need $PG_MAJOR. Starting migration"
 | 
			
		||||
    echo "Installing postgres $DATA_VERSION"
 | 
			
		||||
    sed -i "s/$/ $DATA_VERSION/" /etc/apt/sources.list.d/pgdg.list
 | 
			
		||||
    apt-get update && apt-get install -y --no-install-recommends \
 | 
			
		||||
      postgresql-$DATA_VERSION \
 | 
			
		||||
      && rm -rf /var/lib/apt/lists/*
 | 
			
		||||
    echo "shuffling around"
 | 
			
		||||
    chown -R postgres:postgres $PGDATA
 | 
			
		||||
    gosu postgres mkdir $OLDDATA $NEWDATA
 | 
			
		||||
    chmod 700 $OLDDATA $NEWDATA
 | 
			
		||||
    mv $PGDATA/* $OLDDATA/ || true
 | 
			
		||||
    touch $MIGRATION_MARKER
 | 
			
		||||
    echo "running initdb"
 | 
			
		||||
    # abuse entrypoint script for initdb by making server error out
 | 
			
		||||
    gosu postgres bash -c "export PGDATA=$NEWDATA ; /usr/local/bin/docker-entrypoint.sh --invalid-arg || true"
 | 
			
		||||
    echo "running pg_upgrade"
 | 
			
		||||
    cd /tmp
 | 
			
		||||
    gosu postgres pg_upgrade --link -b /usr/lib/postgresql/$DATA_VERSION/bin -d $OLDDATA -D $NEWDATA -U $POSTGRES_USER
 | 
			
		||||
    cp $OLDDATA/pg_hba.conf $NEWDATA/
 | 
			
		||||
    mv $NEWDATA/* $PGDATA
 | 
			
		||||
    rm -rf $OLDDATA
 | 
			
		||||
    rmdir $NEWDATA
 | 
			
		||||
    rm $MIGRATION_MARKER
 | 
			
		||||
    echo "migration complete"
 | 
			
		||||
  fi
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
/usr/local/bin/docker-entrypoint.sh postgres
 | 
			
		||||
@ -37,7 +37,7 @@ entries:
 | 
			
		||||
    name: default-authentication-login
 | 
			
		||||
  model: authentik_stages_user_login.userloginstage
 | 
			
		||||
  attrs:
 | 
			
		||||
    session_duration: seconds=0
 | 
			
		||||
    session_duration: days=30
 | 
			
		||||
 | 
			
		||||
# After the first run this will produce a RelatedObjectDoesNotExist error
 | 
			
		||||
- identifiers:
 | 
			
		||||
 | 
			
		||||
@ -24,6 +24,18 @@ entries:
 | 
			
		||||
  id: invitation-enrollment-flow
 | 
			
		||||
  model: authentik_flows.flow
 | 
			
		||||
 | 
			
		||||
### POLICIES
 | 
			
		||||
- attrs:
 | 
			
		||||
    expression: |
 | 
			
		||||
      if not regex_match(request.context.get('prompt_data').get('username'), '\s'):
 | 
			
		||||
          return True
 | 
			
		||||
      ak_message("Username must not contain any whitespace!")
 | 
			
		||||
      return False
 | 
			
		||||
  id: username-without-spaces-policy
 | 
			
		||||
  identifiers:
 | 
			
		||||
    name: username-without-spaces-policy
 | 
			
		||||
  model: authentik_policies_expression.expressionpolicy
 | 
			
		||||
 | 
			
		||||
### STAGES
 | 
			
		||||
- identifiers:
 | 
			
		||||
    name: invitation-stage
 | 
			
		||||
@ -41,6 +53,8 @@ entries:
 | 
			
		||||
      - !Find [authentik_stages_prompt.prompt, [name, default-user-settings-field-email]]
 | 
			
		||||
      - !Find [authentik_stages_prompt.prompt, [name, default-password-change-field-password]]
 | 
			
		||||
      - !Find [authentik_stages_prompt.prompt, [name, default-password-change-field-password-repeat]]
 | 
			
		||||
    validation_policies:
 | 
			
		||||
      - !Find [ authentik_policies_expression.expressionpolicy, [name, username-without-spaces-policy]]
 | 
			
		||||
 | 
			
		||||
### STAGE BINDINGS
 | 
			
		||||
- identifiers:
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										43
									
								
								hedgedoc.yaml.tmpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								hedgedoc.yaml.tmpl
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,43 @@
 | 
			
		||||
version: 1
 | 
			
		||||
metadata:
 | 
			
		||||
  labels:
 | 
			
		||||
    blueprints.goauthentik.io/instantiate: "true"
 | 
			
		||||
  name: hedgedoc
 | 
			
		||||
 | 
			
		||||
entries:
 | 
			
		||||
 | 
			
		||||
- attrs:
 | 
			
		||||
    access_code_validity: minutes=1
 | 
			
		||||
    authorization_flow: !Find [authentik_flows.flow, [slug, default-provider-authorization-implicit-consent]]
 | 
			
		||||
    client_id: {{ secret  "hedgedoc_id" }}
 | 
			
		||||
    client_secret: {{ secret  "hedgedoc_secret" }}
 | 
			
		||||
    client_type: confidential
 | 
			
		||||
    include_claims_in_id_token: true
 | 
			
		||||
    issuer_mode: per_provider
 | 
			
		||||
    name: Hedgedoc
 | 
			
		||||
    property_mappings:
 | 
			
		||||
    - !Find [authentik_providers_oauth2.scopemapping, [scope_name, openid]]
 | 
			
		||||
    - !Find [authentik_providers_oauth2.scopemapping, [scope_name, email]]
 | 
			
		||||
    - !Find [authentik_providers_oauth2.scopemapping, [scope_name, profile]]
 | 
			
		||||
    signing_key: !Find [authentik_crypto.certificatekeypair, [name, authentik Self-signed Certificate]]
 | 
			
		||||
    sub_mode: hashed_user_id
 | 
			
		||||
    token_validity: days=30
 | 
			
		||||
  conditions: []
 | 
			
		||||
  id: hedgedoc_provider
 | 
			
		||||
  identifiers:
 | 
			
		||||
    pk: 9992
 | 
			
		||||
  model: authentik_providers_oauth2.oauth2provider
 | 
			
		||||
  state: present
 | 
			
		||||
 | 
			
		||||
- attrs:
 | 
			
		||||
    meta_launch_url: https://{{ env  "HEDGEDOC_DOMAIN" }}
 | 
			
		||||
    open_in_new_tab: true
 | 
			
		||||
    policy_engine_mode: any
 | 
			
		||||
    provider: !KeyOf hedgedoc_provider
 | 
			
		||||
    slug: hedgedoc
 | 
			
		||||
  conditions: []
 | 
			
		||||
  id: hedgedoc_application
 | 
			
		||||
  identifiers:
 | 
			
		||||
    name: Hedgedoc
 | 
			
		||||
  model: authentik_core.application
 | 
			
		||||
  state: present
 | 
			
		||||
							
								
								
									
										
											BIN
										
									
								
								icons/hedgedoc.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								icons/hedgedoc.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| 
		 After Width: | Height: | Size: 9.2 KiB  | 
							
								
								
									
										
											BIN
										
									
								
								icons/outline.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								icons/outline.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| 
		 After Width: | Height: | Size: 6.9 KiB  | 
							
								
								
									
										43
									
								
								outline.yaml.tmpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								outline.yaml.tmpl
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,43 @@
 | 
			
		||||
version: 1
 | 
			
		||||
metadata:
 | 
			
		||||
  labels:
 | 
			
		||||
    blueprints.goauthentik.io/instantiate: "true"
 | 
			
		||||
  name: outline
 | 
			
		||||
 | 
			
		||||
entries:
 | 
			
		||||
 | 
			
		||||
- attrs:
 | 
			
		||||
    access_code_validity: minutes=1
 | 
			
		||||
    authorization_flow: !Find [authentik_flows.flow, [slug, default-provider-authorization-implicit-consent]]
 | 
			
		||||
    client_id: {{ secret  "outline_id" }}
 | 
			
		||||
    client_secret: {{ secret  "outline_secret" }}
 | 
			
		||||
    client_type: confidential
 | 
			
		||||
    include_claims_in_id_token: true
 | 
			
		||||
    issuer_mode: per_provider
 | 
			
		||||
    name: Outline
 | 
			
		||||
    property_mappings:
 | 
			
		||||
    - !Find [authentik_providers_oauth2.scopemapping, [scope_name, openid]]
 | 
			
		||||
    - !Find [authentik_providers_oauth2.scopemapping, [scope_name, email]]
 | 
			
		||||
    - !Find [authentik_providers_oauth2.scopemapping, [scope_name, profile]]
 | 
			
		||||
    signing_key: !Find [authentik_crypto.certificatekeypair, [name, authentik Self-signed Certificate]]
 | 
			
		||||
    sub_mode: hashed_user_id
 | 
			
		||||
    token_validity: days=30
 | 
			
		||||
  conditions: []
 | 
			
		||||
  id: outline_provider
 | 
			
		||||
  identifiers:
 | 
			
		||||
    pk: 9994
 | 
			
		||||
  model: authentik_providers_oauth2.oauth2provider
 | 
			
		||||
  state: present
 | 
			
		||||
 | 
			
		||||
- attrs:
 | 
			
		||||
    meta_launch_url: https://{{ env  "OUTLINE_DOMAIN" }}
 | 
			
		||||
    open_in_new_tab: true
 | 
			
		||||
    policy_engine_mode: any
 | 
			
		||||
    provider: !KeyOf outline_provider
 | 
			
		||||
    slug: outline
 | 
			
		||||
  conditions: []
 | 
			
		||||
  id: outline_application
 | 
			
		||||
  identifiers:
 | 
			
		||||
    name: Outline
 | 
			
		||||
  model: authentik_core.application
 | 
			
		||||
  state: present
 | 
			
		||||
							
								
								
									
										43
									
								
								rallly.yaml.tmpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								rallly.yaml.tmpl
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,43 @@
 | 
			
		||||
version: 1
 | 
			
		||||
metadata:
 | 
			
		||||
  labels:
 | 
			
		||||
    blueprints.goauthentik.io/instantiate: "true"
 | 
			
		||||
  name: rallly
 | 
			
		||||
 | 
			
		||||
entries:
 | 
			
		||||
 | 
			
		||||
- attrs:
 | 
			
		||||
    access_code_validity: minutes=1
 | 
			
		||||
    authorization_flow: !Find [authentik_flows.flow, [slug, default-provider-authorization-implicit-consent]]
 | 
			
		||||
    client_id: {{ secret  "rallly_id" }}
 | 
			
		||||
    client_secret: {{ secret  "rallly_secret" }}
 | 
			
		||||
    client_type: confidential
 | 
			
		||||
    include_claims_in_id_token: true
 | 
			
		||||
    issuer_mode: per_provider
 | 
			
		||||
    name: Rallly
 | 
			
		||||
    property_mappings:
 | 
			
		||||
    - !Find [authentik_providers_oauth2.scopemapping, [scope_name, openid]]
 | 
			
		||||
    - !Find [authentik_providers_oauth2.scopemapping, [scope_name, email]]
 | 
			
		||||
    - !Find [authentik_providers_oauth2.scopemapping, [scope_name, profile]]
 | 
			
		||||
    signing_key: !Find [authentik_crypto.certificatekeypair, [name, authentik Self-signed Certificate]]
 | 
			
		||||
    sub_mode: hashed_user_id
 | 
			
		||||
    token_validity: days=30
 | 
			
		||||
  conditions: []
 | 
			
		||||
  id: rallly_provider
 | 
			
		||||
  identifiers:
 | 
			
		||||
    pk: 9993
 | 
			
		||||
  model: authentik_providers_oauth2.oauth2provider
 | 
			
		||||
  state: present
 | 
			
		||||
 | 
			
		||||
- attrs:
 | 
			
		||||
    meta_launch_url: https://{{ env  "RALLLY_DOMAIN" }}
 | 
			
		||||
    open_in_new_tab: true
 | 
			
		||||
    policy_engine_mode: any
 | 
			
		||||
    provider: !KeyOf rallly_provider
 | 
			
		||||
    slug: rallly
 | 
			
		||||
  conditions: []
 | 
			
		||||
  id: rallly_application
 | 
			
		||||
  identifiers:
 | 
			
		||||
    name: Rallly
 | 
			
		||||
  model: authentik_core.application
 | 
			
		||||
  state: present
 | 
			
		||||
							
								
								
									
										1
									
								
								release/4.0.0+2023.10.5
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								release/4.0.0+2023.10.5
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1 @@
 | 
			
		||||
It is only possible to upgrade to 2023.10 from 2023.8, you need to update to 2023.8.x before applying this update
 | 
			
		||||
							
								
								
									
										1
									
								
								release/5.0.0+2024.2.2
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								release/5.0.0+2024.2.2
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1 @@
 | 
			
		||||
Blueprint changes are applied and automatic migrations should work, however, manual action may be required: https://docs.goauthentik.io/docs/releases/2024.2
 | 
			
		||||
							
								
								
									
										1
									
								
								release/5.1.0+2024.2.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								release/5.1.0+2024.2.3
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1 @@
 | 
			
		||||
Due to blueprint changes, you need to run the following command after upgrading: abra app cmd -C <Domain> worker apply_blueprints
 | 
			
		||||
@ -2,13 +2,13 @@ version: 1
 | 
			
		||||
metadata:
 | 
			
		||||
  labels:
 | 
			
		||||
    blueprints.goauthentik.io/instantiate: "true"
 | 
			
		||||
  name: Custom System Tenant
 | 
			
		||||
  name: Custom System brand
 | 
			
		||||
entries:
 | 
			
		||||
### DEPENDENCIES
 | 
			
		||||
- model: authentik_blueprints.metaapplyblueprint
 | 
			
		||||
  attrs:
 | 
			
		||||
    identifiers:
 | 
			
		||||
      name: Default - Tenant
 | 
			
		||||
      name: Default - Brand
 | 
			
		||||
    required: true
 | 
			
		||||
- model: authentik_blueprints.metaapplyblueprint
 | 
			
		||||
  attrs:
 | 
			
		||||
@ -17,11 +17,11 @@ entries:
 | 
			
		||||
    required: true
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
### SYSTEM TENANT
 | 
			
		||||
# remove custom tenant from old recipe
 | 
			
		||||
### SYSTEM BRAND
 | 
			
		||||
# remove custom brand from old recipe
 | 
			
		||||
- identifiers:
 | 
			
		||||
    domain: {{ env "DOMAIN" }}
 | 
			
		||||
  model: authentik_tenants.tenant
 | 
			
		||||
  model: authentik_brands.brand
 | 
			
		||||
  state: absent
 | 
			
		||||
 | 
			
		||||
- attrs:
 | 
			
		||||
@ -32,4 +32,4 @@ entries:
 | 
			
		||||
  identifiers:
 | 
			
		||||
    default: true
 | 
			
		||||
    domain: authentik-default
 | 
			
		||||
  model: authentik_tenants.tenant
 | 
			
		||||
  model: authentik_brands.brand
 | 
			
		||||
		Reference in New Issue
	
	Block a user