feat: integrate Writefreely #30

Open
luisb wants to merge 2 commits from luisb/authentik:feature/writefreely-integration into main
5 changed files with 95 additions and 0 deletions

View File

@ -163,5 +163,12 @@ COPY_ASSETS="$COPY_ASSETS icon.png|app:/web/dist/assets/icons/"
# APP_ICONS="$APP_ICONS mila:~/.abra/recipes/authentik/icons/mila.svg"
# MILA_APPGROUP=""
# COMPOSE_FILE="$COMPOSE_FILE:compose.writefreely.yml"
# WRITEFREELY_DOMAIN=writefreely.example.com
# SECRET_WRITEFREELY_ID_VERSION=v1
# SECRET_WRITEFREELY_SECRET_VERSION=v1
# APP_ICONS="nextcloud:~/.abra/recipes/authentik/icons/writefreely.png"
# WRITEFREELY_APPGROUP="$GROUP_DOCUMENTATION"
# APPLICATIONS='{"Calendar": {"url":"https://nextcloud.example.com/apps/calendar/", "group": ""}, "BBB": {"url":"https://nextcloud.example.com/apps/bbb/", "group":""}, "Pretix": {"url":"https://pretix.example.com/control/", "group":""}}'
# EXTRA_ICONS={"Calendar": "~/.abra/recipes/authentik/icons/calendar.svg", "BBB": "~/.abra/recipes/authentik/icons/bbb.png", "Pretix": "~/.abra/recipes/authentik/icons/pretix.svg"}

View File

@ -16,6 +16,7 @@ export ZAMMAD_CONFIG_VERSION=v4
export RALLLY_CONFIG_VERSION=v4
export HEDGEDOC_CONFIG_VERSION=v3
export MONITORING_CONFIG_VERSION=v4
export WRITEFREELY_CONFIG_VERSION=v1
export MILA_CONFIG_VERSION=v1
export DB_ENTRYPOINT_VERSION=v1
export PG_BACKUP_VERSION=v2

26
compose.writefreely.yml Normal file
View File

@ -0,0 +1,26 @@
version: "3.8"
services:
worker:
secrets:
- writefreely_id
- writefreely_secret
environment:
- WRITEFREELY_DOMAIN
configs:
- source: writefreely
target: /blueprints/writefreely.yaml
secrets:
writefreely_id:
external: true
name: ${STACK_NAME}_writefreely_id_${SECRET_WRITEFREELY_ID_VERSION}
writefreely_secret:
external: true
name: ${STACK_NAME}_writefreely_secret_${SECRET_WRITEFREELY_SECRET_VERSION}
configs:
writefreely:
name: ${STACK_NAME}_writefreely_${WRITEFREELY_CONFIG_VERSION}
file: writefreely.yaml.tmpl
template_driver: golang

BIN
icons/writefreely.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 12 KiB

61
writefreely.yaml.tmpl Normal file
View File

@ -0,0 +1,61 @@
version: 1
metadata:
labels:
blueprints.goauthentik.io/instantiate: "true"
name: Writefreely
entries:
- attrs:
description: writefreely
expression: 'return { "writefreely_groups": [{"gid": group.name, "displayName":
group.name} for group in request.user.ak_groups.all()], }'
managed: null
scope_name: writefreely
conditions: []
id: writefreely_group_mapping
identifiers:
name: writefreely
model: authentik_providers_oauth2.scopemapping
state: present
- attrs:
access_code_validity: minutes=1
authentication_flow: !Find [authentik_flows.flow, [slug, default-authentication-flow]]
authorization_flow: !Find [authentik_flows.flow, [slug, default-provider-authorization-implicit-consent]]
invalidation_flow: !Find [authentik_flows.flow, [slug, default-provider-invalidation-flow]]
client_id: {{ secret "writefreely_id" }}
client_secret: {{ secret "writefreely_secret" }}
client_type: confidential
include_claims_in_id_token: true
issuer_mode: per_provider
redirect_uris:
- matching_mode: strict
url: https://{{ env "WRITEFREELY_DOMAIN" }}/oauth/callback/generic
name: Writefreely
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]]
- !KeyOf writefreely_group_mapping
signing_key: !Find [authentik_crypto.certificatekeypair, [name, authentik Self-signed Certificate]]
sub_mode: user_username
token_validity: days=30
conditions: []
id: writefreely_provider
identifiers:
pk: 9988
model: authentik_providers_oauth2.oauth2provider
state: present
- attrs:
meta_launch_url: https://{{ env "WRITEFREELY_DOMAIN" }}
open_in_new_tab: true
policy_engine_mode: any
provider: !KeyOf writefreely_provider
slug: writefreely
conditions: []
id: writefreely_application
identifiers:
name: Writefreely
model: authentik_core.application
state: present