9a98c1be00
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
78 lines
3.1 KiB
Markdown
78 lines
3.1 KiB
Markdown
# File structure
|
|
|
|
Blueprints are YAML files, which can use some additional tags to ease blueprint creation.
|
|
|
|
## Schema
|
|
|
|
The blueprint schema is available under `https://goauthentik.io/blueprints/schema.json`. It is also possible to target a specific version's blueprint schema by using `https://version-2023-4.goauthentik.io/blueprints/schema.json`.
|
|
|
|
To use the schema with Visual Studio code and the YAML extension, add this comment at the top of your blueprint files:
|
|
|
|
```yaml
|
|
# yaml-language-server: $schema=https://goauthentik.io/blueprints/schema.json
|
|
```
|
|
|
|
## Example
|
|
|
|
```yaml
|
|
# yaml-language-server: $schema=https://goauthentik.io/blueprints/schema.json
|
|
# The version of this blueprint, currently 1
|
|
version: 1
|
|
# Optional block of metadata, name is required if metadata is set
|
|
metadata:
|
|
# Arbitrary key=value store, special labels are listed below
|
|
labels:
|
|
foo: bar
|
|
name: example-blueprint
|
|
# Optional default context, instance context is merged over this.
|
|
context:
|
|
foo: bar
|
|
# List of entries (required)
|
|
entries:
|
|
- # Model in app.model notation, possibilities are listed in the schema (required)
|
|
model: authentik_flows.flow
|
|
# The state this object should be in (optional, can be "present", "created" or "absent")
|
|
# Present will keep the object in sync with its definition here, created will only ensure
|
|
# the object is created (and create it with the values given here), and "absent" will
|
|
# delete the object
|
|
state: present
|
|
# An optional list of boolean-like conditions. If all conditions match (or
|
|
# no condiitons are provided) the entry will be evaluated and acted upon
|
|
# as normal. Otherwise, the entry is skipped as if not defined at all.
|
|
# Each condition will be evaluated in Python to its boolean representation
|
|
# bool(<condition>). Furthermore, complex conditions can be built using
|
|
# a special !Condition tag. See the documentattion for custom tags for more
|
|
# information.
|
|
conditions:
|
|
- true
|
|
- text
|
|
- 2
|
|
- !Condition [AND, ...] # See custom tags section
|
|
# Key:value filters to uniquely identify this object (required)
|
|
identifiers:
|
|
slug: initial-setup
|
|
# Optional ID for use with !KeyOf
|
|
id: flow
|
|
# Attributes to set on the object. Only explicitly required settings should be stated
|
|
# as these values will override existing attributes
|
|
attrs:
|
|
denied_action: message_continue
|
|
designation: stage_configuration
|
|
name: default-oobe-setup
|
|
title: Welcome to authentik!
|
|
```
|
|
|
|
## Special Labels
|
|
|
|
#### `blueprints.goauthentik.io/system`:
|
|
|
|
Used by authentik's packaged blueprints to keep globals up-to-date. Should only be removed in special cases.
|
|
|
|
#### `blueprints.goauthentik.io/instantiate`:
|
|
|
|
Configure if this blueprint should automatically be instantiated (defaults to `"true"`). When set to `"false"`, blueprints are listed and available to be instantiated via API/Browser.
|
|
|
|
#### `blueprints.goauthentik.io/description`:
|
|
|
|
Optionally set a description, which can be seen in the web interface.
|