forked from coop-cloud/authentik
		
	Compare commits
	
		
			1 Commits
		
	
	
		
			6.1.1+2024
			...
			validate-u
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 00608c1143 | 
@ -23,7 +23,7 @@ steps:
 | 
			
		||||
      FLOW_INVALIDATION_VERSION: v1
 | 
			
		||||
      FLOW_RECOVERY_VERSION: v1
 | 
			
		||||
      FLOW_TRANSLATION_VERSION: v1
 | 
			
		||||
      SYSTEM_BRAND_VERSION: v1
 | 
			
		||||
      SYSTEM_TENANT_VERSION: v1
 | 
			
		||||
      NEXTCLOUD_CONFIG_VERSION: v1
 | 
			
		||||
      SECRET_SECRET_KEY_VERSION: v1
 | 
			
		||||
      SECRET_DB_PASSWORD_VERSION: v1
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										19
									
								
								.env.sample
									
									
									
									
									
								
							
							
						
						
									
										19
									
								
								.env.sample
									
									
									
									
									
								
							@ -34,6 +34,7 @@ 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"
 | 
			
		||||
@ -46,12 +47,6 @@ 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
 | 
			
		||||
@ -89,12 +84,6 @@ AUTHENTIK_COLOR_BACKGROUND_LIGHT=#1c1e21
 | 
			
		||||
# SECRET_OUTLINE_SECRET_VERSION=v1
 | 
			
		||||
# APP_ICONS="$APP_ICONS outline:~/.abra/recipes/authentik/icons/outline.png"
 | 
			
		||||
 | 
			
		||||
# COMPOSE_FILE="$COMPOSE_FILE:compose.kimai.yml"
 | 
			
		||||
# KIMAI_DOMAIN=kimai.example.com
 | 
			
		||||
# SECRET_KIMAI_ID_VERSION=v1
 | 
			
		||||
# SECRET_KIMAI_SECRET_VERSION=v1
 | 
			
		||||
# APP_ICONS="$APP_ICONS kimai:~/.abra/recipes/authentik/icons/kimai.png"
 | 
			
		||||
 | 
			
		||||
# COMPOSE_FILE="$COMPOSE_FILE:compose.monitoring.yml"
 | 
			
		||||
# MONITORING_DOMAIN=monitoring.example.com
 | 
			
		||||
# SECRET_MONITORING_ID_VERSION=v1
 | 
			
		||||
@ -107,12 +96,6 @@ AUTHENTIK_COLOR_BACKGROUND_LIGHT=#1c1e21
 | 
			
		||||
# 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 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 Brand
 | 
			
		||||
    - Default - Brand
 | 
			
		||||
        - APPEND: `authentik_brands.brand  domain: authentik-default`
 | 
			
		||||
- Custom System Tenant
 | 
			
		||||
    - Default - Tenant
 | 
			
		||||
        - APPEND: `authentik_tenants.tenant  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 Brand
 | 
			
		||||
    - Default - Brand
 | 
			
		||||
5. Custom System Tenant
 | 
			
		||||
    - Default - Tenant
 | 
			
		||||
    1. Recovery with email verification
 | 
			
		||||
        - Default - Authentication flow
 | 
			
		||||
            - Default - Password change flow
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										37
									
								
								abra.sh
									
									
									
									
									
								
							
							
						
						
									
										37
									
								
								abra.sh
									
									
									
									
									
								
							@ -1,19 +1,17 @@
 | 
			
		||||
export CUSTOM_CSS_VERSION=v2
 | 
			
		||||
export FLOW_AUTHENTICATION_VERSION=v4
 | 
			
		||||
export FLOW_INVITATION_VERSION=v2
 | 
			
		||||
export FLOW_AUTHENTICATION_VERSION=v3
 | 
			
		||||
export FLOW_INVITATION_VERSION=v1
 | 
			
		||||
export FLOW_INVALIDATION_VERSION=v2
 | 
			
		||||
export FLOW_RECOVERY_VERSION=v1
 | 
			
		||||
export FLOW_TRANSLATION_VERSION=v3
 | 
			
		||||
export SYSTEM_BRAND_VERSION=v3
 | 
			
		||||
export FLOW_TRANSLATION_VERSION=v2
 | 
			
		||||
export SYSTEM_TENANT_VERSION=v2
 | 
			
		||||
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 KIMAI_CONFIG_VERSION=v1
 | 
			
		||||
export RALLLY_CONFIG_VERSION=v2
 | 
			
		||||
export HEDGEDOC_CONFIG_VERSION=v1
 | 
			
		||||
export OUTLINE_CONFIG_VERSION=v1
 | 
			
		||||
export RALLLY_CONFIG_VERSION=v1
 | 
			
		||||
export MONITORING_CONFIG_VERSION=v1
 | 
			
		||||
export DB_ENTRYPOINT_VERSION=v1
 | 
			
		||||
 | 
			
		||||
@ -56,19 +54,15 @@ with open('/tmp/$1', newline='') as file:
 | 
			
		||||
    email = row[2].strip()
 | 
			
		||||
    groups = row[3].split(';')
 | 
			
		||||
    if User.objects.filter(username=username):
 | 
			
		||||
        print(f'{username} already exists')
 | 
			
		||||
        continue
 | 
			
		||||
    new_user = User.objects.create(name=name, username=username, email=email)
 | 
			
		||||
    print(f'{username} created')
 | 
			
		||||
    for group_name in groups:
 | 
			
		||||
        group_name = group_name.strip()
 | 
			
		||||
        if Group.objects.filter(name=group_name):
 | 
			
		||||
            group = Group.objects.get(name=group_name)
 | 
			
		||||
        else:
 | 
			
		||||
            group = Group.objects.create(name=group_name)
 | 
			
		||||
            print(f'{group_name} created')
 | 
			
		||||
        group.users.add(new_user)
 | 
			
		||||
        print(f'add {username} to group {group_name}')
 | 
			
		||||
""" 2>&1 | quieten
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -176,9 +170,7 @@ for name, url in applications.items():
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
quieten(){
 | 
			
		||||
    # 'SyntaxWarning|version_regex|"http\['
 | 
			
		||||
    # is a workaround to get rid of some verbose syntax warnings, this might be fixed with another version
 | 
			
		||||
    grep -Pv '"level": "(info|debug)"|SyntaxWarning|version_regex|"http\['
 | 
			
		||||
    grep -v -e '{"event"' -e '{"action"'
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
add_email_templates(){
 | 
			
		||||
@ -225,20 +217,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()
 | 
			
		||||
Brand.objects.filter(default=True).delete()
 | 
			
		||||
Tenant.objects.filter(default=True).delete()
 | 
			
		||||
""" 2>&1 | quieten
 | 
			
		||||
apply_blueprints
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
get_certificate() {
 | 
			
		||||
/manage.py shell -c """
 | 
			
		||||
provider_name='$1'
 | 
			
		||||
if not provider_name:
 | 
			
		||||
    print('no Provider Name given')
 | 
			
		||||
    exit(1)
 | 
			
		||||
provider = Provider.objects.filter(name=provider_name).first()
 | 
			
		||||
saml = provider.samlprovider
 | 
			
		||||
cert = saml.signing_kp
 | 
			
		||||
print(''.join(cert.certificate_data.splitlines()[1:-1]))
 | 
			
		||||
""" 2>&1 | quieten
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -1,76 +0,0 @@
 | 
			
		||||
nextcloud:
 | 
			
		||||
    uncomment:
 | 
			
		||||
        - compose.nextcloud.yml
 | 
			
		||||
        - NEXTCLOUD_DOMAIN
 | 
			
		||||
        - SECRET_NEXTCLOUD_ID_VERSION
 | 
			
		||||
        - SECRET_NEXTCLOUD_SECRET_VERSION
 | 
			
		||||
        - nextcloud.png
 | 
			
		||||
wordpress:
 | 
			
		||||
    uncomment:
 | 
			
		||||
        - compose.wordpress.yml
 | 
			
		||||
        - WORDPRESS_DOMAIN
 | 
			
		||||
        - WORDPRESS_GROUP
 | 
			
		||||
        - SECRET_WORDPRESS_ID_VERSION
 | 
			
		||||
        - SECRET_WORDPRESS_SECRET_VERSION
 | 
			
		||||
        - wordpress.png
 | 
			
		||||
matrix-synapse:
 | 
			
		||||
    uncomment:
 | 
			
		||||
        - compose.matrix.yml
 | 
			
		||||
        - ELEMENT_DOMAIN
 | 
			
		||||
        - SECRET_MATRIX_ID_VERSION
 | 
			
		||||
        - SECRET_MATRIX_SECRET_VERSION
 | 
			
		||||
        - matrix.svg
 | 
			
		||||
    secrets:
 | 
			
		||||
        matrix_id: matrix
 | 
			
		||||
wekan:
 | 
			
		||||
    uncomment:
 | 
			
		||||
        - compose.wekan.yml
 | 
			
		||||
        - WEKAN_DOMAIN
 | 
			
		||||
        - SECRET_WEKAN_ID_VERSION
 | 
			
		||||
        - SECRET_WEKAN_SECRET_VERSION
 | 
			
		||||
        - wekan.png
 | 
			
		||||
    secrets:
 | 
			
		||||
        wekan_id: wekan
 | 
			
		||||
vikunja:
 | 
			
		||||
    uncomment:
 | 
			
		||||
        - compose.vikunja.yml
 | 
			
		||||
        - VIKUNJA_DOMAIN
 | 
			
		||||
        - SECRET_VIKUNJA_ID_VERSION
 | 
			
		||||
        - SECRET_VIKUNJA_SECRET_VERSION
 | 
			
		||||
        - vikunja.svg
 | 
			
		||||
    secrets:
 | 
			
		||||
        vikunja_id: vikunja
 | 
			
		||||
monitoring:
 | 
			
		||||
    uncomment:
 | 
			
		||||
        - compose.monitoring.yml
 | 
			
		||||
        - MONITORING_DOMAIN
 | 
			
		||||
        - SECRET_MONITORING_ID_VERSION
 | 
			
		||||
        - SECRET_MONITORING_SECRET_VERSION
 | 
			
		||||
        - monitoring.png
 | 
			
		||||
outline:
 | 
			
		||||
    uncomment:
 | 
			
		||||
        - compose.outline.yml
 | 
			
		||||
        - OUTLINE_DOMAIN
 | 
			
		||||
        - SECRET_OUTLINE_ID_VERSION
 | 
			
		||||
        - SECRET_OUTLINE_SECRET_VERSION
 | 
			
		||||
        - outline.png
 | 
			
		||||
    secrets:
 | 
			
		||||
        outline_id: outline
 | 
			
		||||
rallly:
 | 
			
		||||
    uncomment:  
 | 
			
		||||
        - compose.rallly.yml
 | 
			
		||||
        - RALLLY_DOMAIN
 | 
			
		||||
        - SECRET_RALLLY_ID_VERSION
 | 
			
		||||
        - SECRET_RALLLY_SECRET_VERSION
 | 
			
		||||
        - rallly.png
 | 
			
		||||
    secrets:
 | 
			
		||||
        rallly_id: rallly
 | 
			
		||||
hedgedoc:
 | 
			
		||||
    uncomment:  
 | 
			
		||||
        - compose.hedgedoc.yml
 | 
			
		||||
        - HEDGEDOC_DOMAIN
 | 
			
		||||
        - SECRET_HEDGEDOC_ID_VERSION
 | 
			
		||||
        - SECRET_HEDGEDOC_SECRET_VERSION
 | 
			
		||||
        - hedgedoc.png
 | 
			
		||||
    secrets:
 | 
			
		||||
        hedgedoc_id: hedgedoc
 | 
			
		||||
@ -1,14 +0,0 @@
 | 
			
		||||
---
 | 
			
		||||
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
 | 
			
		||||
@ -1,26 +0,0 @@
 | 
			
		||||
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
 | 
			
		||||
@ -1,14 +0,0 @@
 | 
			
		||||
version: "3.8"
 | 
			
		||||
services:
 | 
			
		||||
  worker:
 | 
			
		||||
    environment:
 | 
			
		||||
      - KIMAI_DOMAIN
 | 
			
		||||
    configs:
 | 
			
		||||
      - source: kimai
 | 
			
		||||
        target: /blueprints/kimai.yaml
 | 
			
		||||
 | 
			
		||||
configs:
 | 
			
		||||
  kimai:
 | 
			
		||||
    name: ${STACK_NAME}_kimai_${KIMAI_CONFIG_VERSION}
 | 
			
		||||
    file: kimai.yaml.tmpl
 | 
			
		||||
    template_driver: golang
 | 
			
		||||
							
								
								
									
										25
									
								
								compose.yml
									
									
									
									
									
								
							
							
						
						
									
										25
									
								
								compose.yml
									
									
									
									
									
								
							@ -32,7 +32,7 @@ x-env: &env
 | 
			
		||||
version: '3.8'
 | 
			
		||||
services:
 | 
			
		||||
  app:
 | 
			
		||||
    image: ghcr.io/goauthentik/server:2024.4.2
 | 
			
		||||
    image: ghcr.io/goauthentik/server:2023.10.7
 | 
			
		||||
    command: server
 | 
			
		||||
    depends_on:
 | 
			
		||||
      - db
 | 
			
		||||
@ -47,6 +47,9 @@ services:
 | 
			
		||||
      - media:/media
 | 
			
		||||
      - assets:/web/dist/assets
 | 
			
		||||
      - templates:/templates
 | 
			
		||||
    configs:
 | 
			
		||||
      - source: custom_css
 | 
			
		||||
        target: /web/dist/custom.css
 | 
			
		||||
    networks:
 | 
			
		||||
      - internal
 | 
			
		||||
      - proxy
 | 
			
		||||
@ -73,11 +76,11 @@ 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=6.1.1+2024.4.2"
 | 
			
		||||
        - "coop-cloud.${STACK_NAME}.version=4.2.0+2023.10.7"
 | 
			
		||||
        - "coop-cloud.${STACK_NAME}.timeout=${TIMEOUT:-120}"
 | 
			
		||||
 | 
			
		||||
  worker:
 | 
			
		||||
    image: ghcr.io/goauthentik/server:2024.4.2
 | 
			
		||||
    image: ghcr.io/goauthentik/server:2023.10.7
 | 
			
		||||
    command: worker
 | 
			
		||||
    depends_on:
 | 
			
		||||
      - db
 | 
			
		||||
@ -105,14 +108,14 @@ services:
 | 
			
		||||
        target: /blueprints/3_flow_translation.yaml
 | 
			
		||||
      - source: flow_invitation
 | 
			
		||||
        target: /blueprints/4_flow_invitation.yaml
 | 
			
		||||
      - source: system_brand
 | 
			
		||||
        target: /blueprints/5_system_brand.yaml
 | 
			
		||||
      - source: system_tenant
 | 
			
		||||
        target: /blueprints/5_system_tenant.yaml
 | 
			
		||||
      - source: flow_invalidation
 | 
			
		||||
        target: /blueprints/6_flow_invalidation.yaml
 | 
			
		||||
    environment: *env
 | 
			
		||||
 | 
			
		||||
  db:
 | 
			
		||||
    image: postgres:15.7
 | 
			
		||||
    image: postgres:15.5
 | 
			
		||||
    secrets:
 | 
			
		||||
      - db_password
 | 
			
		||||
    configs:
 | 
			
		||||
@ -183,6 +186,10 @@ 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
 | 
			
		||||
@ -203,9 +210,9 @@ configs:
 | 
			
		||||
    name: ${STACK_NAME}_flow_translation_${FLOW_TRANSLATION_VERSION}
 | 
			
		||||
    file: flow_translation.yaml.tmpl
 | 
			
		||||
    template_driver: golang
 | 
			
		||||
  system_brand:
 | 
			
		||||
    name: ${STACK_NAME}_system_brand_${SYSTEM_BRAND_VERSION}
 | 
			
		||||
    file: system_brand.yaml.tmpl
 | 
			
		||||
  system_tenant:
 | 
			
		||||
    name: ${STACK_NAME}_system_tenant_${SYSTEM_TENANT_VERSION}
 | 
			
		||||
    file: system_tenant.yaml.tmpl
 | 
			
		||||
    template_driver: golang
 | 
			
		||||
  db_entrypoint:
 | 
			
		||||
    name: ${STACK_NAME}_db_entrypoint_${DB_ENTRYPOINT_VERSION}
 | 
			
		||||
 | 
			
		||||
@ -384,7 +384,7 @@ entries:
 | 
			
		||||
    enabled: {{ if eq (env "LOGOUT_REDIRECT") "" }} false {{ else }} true {{ end }}
 | 
			
		||||
    timeout: 30
 | 
			
		||||
 | 
			
		||||
######## System Brand ##########
 | 
			
		||||
######## System Tenant ##########
 | 
			
		||||
- 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_brand
 | 
			
		||||
  model: authentik_brands.brand
 | 
			
		||||
  id: system_tenant
 | 
			
		||||
  model: authentik_tenants.tenant
 | 
			
		||||
 | 
			
		||||
@ -37,7 +37,7 @@ entries:
 | 
			
		||||
    name: default-authentication-login
 | 
			
		||||
  model: authentik_stages_user_login.userloginstage
 | 
			
		||||
  attrs:
 | 
			
		||||
    session_duration: days=30
 | 
			
		||||
    session_duration: seconds=0
 | 
			
		||||
 | 
			
		||||
# After the first run this will produce a RelatedObjectDoesNotExist error
 | 
			
		||||
- identifiers:
 | 
			
		||||
 | 
			
		||||
@ -26,16 +26,22 @@ entries:
 | 
			
		||||
 | 
			
		||||
### 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
 | 
			
		||||
    expression: "if not regex_match(request.context.get('prompt_data').get('username'),\
 | 
			
		||||
      \ '\\s'):\n    return True\n\nak_message(\"Username must not contain\
 | 
			
		||||
      \ whitespace!\")\nreturn False"
 | 
			
		||||
    name: username-without-spaces-policy
 | 
			
		||||
  id: username-without-spaces-policy
 | 
			
		||||
  identifiers:
 | 
			
		||||
    name: username-without-spaces-policy
 | 
			
		||||
  model: authentik_policies_expression.expressionpolicy
 | 
			
		||||
 | 
			
		||||
### POLICY BINDINGS
 | 
			
		||||
- identifiers:
 | 
			
		||||
    policy: !KeyOf username-without-spaces-policy
 | 
			
		||||
    target: !KeyOf prompt-stage-binding
 | 
			
		||||
    order: 10
 | 
			
		||||
  model: authentik_policies.policybinding
 | 
			
		||||
 | 
			
		||||
### STAGES
 | 
			
		||||
- identifiers:
 | 
			
		||||
    name: invitation-stage
 | 
			
		||||
@ -53,8 +59,6 @@ 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:
 | 
			
		||||
@ -67,6 +71,7 @@ entries:
 | 
			
		||||
    stage: !KeyOf enrollment-prompt-userdata
 | 
			
		||||
    target: !KeyOf invitation-enrollment-flow
 | 
			
		||||
  model: authentik_flows.flowstagebinding
 | 
			
		||||
  id: prompt-stage-binding
 | 
			
		||||
- identifiers:
 | 
			
		||||
    order: 20
 | 
			
		||||
    stage: !Find [authentik_stages_user_write.userwritestage, [name,  default-source-enrollment-write]]
 | 
			
		||||
 | 
			
		||||
@ -69,3 +69,16 @@ entries:
 | 
			
		||||
  attrs:
 | 
			
		||||
    label: !Context transl_username
 | 
			
		||||
    placeholder: !Context transl_username
 | 
			
		||||
 | 
			
		||||
### POLICIES
 | 
			
		||||
- model: authentik_policies_expression.expressionpolicy
 | 
			
		||||
  identifiers:
 | 
			
		||||
    name: username-without-spaces-policy
 | 
			
		||||
  attrs:
 | 
			
		||||
    expression: "if not regex_match(request.context.get('prompt_data').get('username'),\
 | 
			
		||||
      \ '\\s'):\n    return True\n\nak_message(\"Benutzername darf kein Leerzeichen\
 | 
			
		||||
      \ enthalten\")\nreturn False"
 | 
			
		||||
      name: username-without-spaces-policy
 | 
			
		||||
  id: username-without-spaces-policy
 | 
			
		||||
 | 
			
		||||
Benutzername darf kein Leerzeichen enthalten\")\n
 | 
			
		||||
@ -1,43 +0,0 @@
 | 
			
		||||
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
 | 
			
		||||
										
											Binary file not shown.
										
									
								
							| 
		 Before Width: | Height: | Size: 9.2 KiB  | 
										
											Binary file not shown.
										
									
								
							| 
		 Before Width: | Height: | Size: 30 KiB  | 
@ -1,48 +0,0 @@
 | 
			
		||||
version: 1
 | 
			
		||||
metadata:
 | 
			
		||||
  labels:
 | 
			
		||||
    blueprints.goauthentik.io/instantiate: "true"
 | 
			
		||||
  name: kimai
 | 
			
		||||
 | 
			
		||||
entries:
 | 
			
		||||
- attrs:
 | 
			
		||||
    acs_url: https://{{ env  "KIMAI_DOMAIN" }}/auth/saml/acs
 | 
			
		||||
    assertion_valid_not_before: minutes=-5
 | 
			
		||||
    assertion_valid_not_on_or_after: minutes=5
 | 
			
		||||
    audience: https://{{ env  "KIMAI_DOMAIN" }}/auth/saml
 | 
			
		||||
    authentication_flow: !Find [authentik_flows.flow, [slug, default-authentication-flow]]
 | 
			
		||||
    authorization_flow: !Find [authentik_flows.flow, [slug, default-provider-authorization-implicit-consent]]
 | 
			
		||||
    digest_algorithm: http://www.w3.org/2001/04/xmlenc#sha256
 | 
			
		||||
    issuer: https://{{ env  "DOMAIN" }}
 | 
			
		||||
    name: Kimai
 | 
			
		||||
    name_id_mapping: !Find [authentik_providers_saml.samlpropertymapping, [name, "authentik default SAML Mapping: Username"]]
 | 
			
		||||
    property_mappings:
 | 
			
		||||
    - !Find [authentik_providers_saml.samlpropertymapping, [name, "authentik default SAML Mapping: Name"]]
 | 
			
		||||
    - !Find [authentik_providers_saml.samlpropertymapping, [name, "authentik default SAML Mapping: Email"]]
 | 
			
		||||
    - !Find [authentik_providers_saml.samlpropertymapping, [name, "authentik default SAML Mapping: User ID"]]
 | 
			
		||||
    - !Find [authentik_providers_saml.samlpropertymapping, [name, "authentik default SAML Mapping: Username"]]
 | 
			
		||||
    - !Find [authentik_providers_saml.samlpropertymapping, [name, "authentik default SAML Mapping: Groups"]]
 | 
			
		||||
    - !Find [authentik_providers_saml.samlpropertymapping, [name, "authentik default SAML Mapping: UPN"]]
 | 
			
		||||
    session_valid_not_on_or_after: minutes=86400
 | 
			
		||||
    signature_algorithm: http://www.w3.org/2001/04/xmldsig-more#rsa-sha256
 | 
			
		||||
    signing_kp: !Find [authentik_crypto.certificatekeypair, [name, authentik Self-signed Certificate]]
 | 
			
		||||
    sp_binding: post
 | 
			
		||||
  conditions: []
 | 
			
		||||
  id: kimai_provider
 | 
			
		||||
  identifiers:
 | 
			
		||||
    pk: 9991
 | 
			
		||||
  model: authentik_providers_saml.samlprovider
 | 
			
		||||
  state: present
 | 
			
		||||
 | 
			
		||||
- attrs:
 | 
			
		||||
    meta_launch_url: https://{{ env  "KIMAI_DOMAIN" }}
 | 
			
		||||
    open_in_new_tab: true
 | 
			
		||||
    policy_engine_mode: any
 | 
			
		||||
    provider: !KeyOf kimai_provider
 | 
			
		||||
    slug: kimai
 | 
			
		||||
  conditions: []
 | 
			
		||||
  id: kimai_application
 | 
			
		||||
  identifiers:
 | 
			
		||||
    name: Kimai
 | 
			
		||||
  model: authentik_core.application
 | 
			
		||||
  state: present
 | 
			
		||||
@ -25,7 +25,7 @@ entries:
 | 
			
		||||
  conditions: []
 | 
			
		||||
  id: outline_provider
 | 
			
		||||
  identifiers:
 | 
			
		||||
    pk: 9994
 | 
			
		||||
    pk: 9995
 | 
			
		||||
  model: authentik_providers_oauth2.oauth2provider
 | 
			
		||||
  state: present
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -25,7 +25,7 @@ entries:
 | 
			
		||||
  conditions: []
 | 
			
		||||
  id: rallly_provider
 | 
			
		||||
  identifiers:
 | 
			
		||||
    pk: 9993
 | 
			
		||||
    pk: 9995
 | 
			
		||||
  model: authentik_providers_oauth2.oauth2provider
 | 
			
		||||
  state: present
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -1 +0,0 @@
 | 
			
		||||
Blueprint changes are applied and automatic migrations should work, however, manual action may be required: https://docs.goauthentik.io/docs/releases/2024.2
 | 
			
		||||
@ -1 +0,0 @@
 | 
			
		||||
Due to blueprint changes, you need to run the following command after upgrading: abra app cmd -C <Domain> worker apply_blueprints
 | 
			
		||||
@ -1 +0,0 @@
 | 
			
		||||
Alerta! ⚠️ If you are using AUTHENTIK_COLOR_BACKGROUND_LIGHT, you will need to set COMPOSE_FILE="$COMPOSE_FILE:compose.css.yml"
 | 
			
		||||
@ -1 +0,0 @@
 | 
			
		||||
Blueprint for Kimai SSO integration added
 | 
			
		||||
@ -2,13 +2,13 @@ version: 1
 | 
			
		||||
metadata:
 | 
			
		||||
  labels:
 | 
			
		||||
    blueprints.goauthentik.io/instantiate: "true"
 | 
			
		||||
  name: Custom System brand
 | 
			
		||||
  name: Custom System Tenant
 | 
			
		||||
entries:
 | 
			
		||||
### DEPENDENCIES
 | 
			
		||||
- model: authentik_blueprints.metaapplyblueprint
 | 
			
		||||
  attrs:
 | 
			
		||||
    identifiers:
 | 
			
		||||
      name: Default - Brand
 | 
			
		||||
      name: Default - Tenant
 | 
			
		||||
    required: true
 | 
			
		||||
- model: authentik_blueprints.metaapplyblueprint
 | 
			
		||||
  attrs:
 | 
			
		||||
@ -17,11 +17,11 @@ entries:
 | 
			
		||||
    required: true
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
### SYSTEM BRAND
 | 
			
		||||
# remove custom brand from old recipe
 | 
			
		||||
### SYSTEM TENANT
 | 
			
		||||
# remove custom tenant from old recipe
 | 
			
		||||
- identifiers:
 | 
			
		||||
    domain: {{ env "DOMAIN" }}
 | 
			
		||||
  model: authentik_brands.brand
 | 
			
		||||
  model: authentik_tenants.tenant
 | 
			
		||||
  state: absent
 | 
			
		||||
 | 
			
		||||
- attrs:
 | 
			
		||||
@ -32,4 +32,4 @@ entries:
 | 
			
		||||
  identifiers:
 | 
			
		||||
    default: true
 | 
			
		||||
    domain: authentik-default
 | 
			
		||||
  model: authentik_brands.brand
 | 
			
		||||
  model: authentik_tenants.tenant
 | 
			
		||||
		Reference in New Issue
	
	Block a user