 6d5172d18a
			
		
	
	6d5172d18a
	
	
	
		
			
			* first pass
* dependency shenanigans
* move blueprints
* few broken links
* change config the throw errors
* internal file edits
* fighting links
* remove sidebarDev
* fix subdomain
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
* fix relative URL
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
* fix mismatched package versions
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
* fix api reference build
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
* test tweak
* links hell
* more links hell
* links hell2
* yep last of the links
* last broken link fixed
* re-add cves
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
* add devdocs redirects
* add dir
* tweak netlify.toml
* move latest 2 CVES into dir
* fix links to moved cves
* typoed title fix
* fix link
* remove banner
* remove committed api docs
Signed-off-by: Marc 'risson' Schmitt <marc.schmitt@risson.space>
* integrations: remove version dropdown
Signed-off-by: Marc 'risson' Schmitt <marc.schmitt@risson.space>
* Update Makefile
Signed-off-by: Marc 'risson' Schmitt <marc.schmitt@risson.space>
* change doc links in web as well
Signed-off-by: Marc 'risson' Schmitt <marc.schmitt@risson.space>
* fix some more docs paths
Signed-off-by: Marc 'risson' Schmitt <marc.schmitt@risson.space>
* fix more docs paths
Signed-off-by: Marc 'risson' Schmitt <marc.schmitt@risson.space>
* ci: require ci-web.build for merging
Signed-off-by: Marc 'risson' Schmitt <marc.schmitt@risson.space>
* Revert "ci: require ci-web.build for merging"
This reverts commit b99a4842a9.
* remove sluf for Application
* put slug back in
* minor fix to trigger deploy
* Spelled out Documentation in menu bar
* remove image redirects...
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
* remove explicit index.md
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
* remove mdx first
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
* then remove .md
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
* add missing prefix
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
---------
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
Signed-off-by: Marc 'risson' Schmitt <marc.schmitt@risson.space>
Co-authored-by: Tana M Berry <tana@goauthentik.com>
Co-authored-by: Jens Langhammer <jens@goauthentik.io>
Co-authored-by: Marc 'risson' Schmitt <marc.schmitt@risson.space>
		
	
		
			
				
	
	
		
			70 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| title: Flow executor (backend)
 | |
| ---
 | |
| 
 | |
| A big focus of authentik is the flows system, which allows you to combine and build complex conditional processes using stages and policies. Normally, these flows are automatically executed in the browser using authentik's [standard browser-based flow executor (/if/flows)](../../add-secure-apps/flows-stages/flow/executors/if-flow.md).
 | |
| 
 | |
| However, any flow can be executed via an API from anywhere, in fact that is what every flow executor does. With a few requests you can execute flows from anywhere, and integrate authentik even better.
 | |
| 
 | |
| :::info
 | |
| Because the flow executor stores its state in the HTTP Session, so you need to ensure that cookies between flow executor requests are persisted.
 | |
| :::
 | |
| 
 | |
| The main endpoint for flow execution is `/api/v3/flows/executor/:slug`.
 | |
| 
 | |
| This endpoint accepts a query parameter called `query`, in which the flow executor sends the full query-string.
 | |
| 
 | |
| To initiate a new flow, execute a GET request.
 | |
| 
 | |
| ## `GET /api/v3/flows/executor/test-flow/`
 | |
| 
 | |
| Below is the response, for example for an Identification stage.
 | |
| 
 | |
| ```json
 | |
| {
 | |
|     "type": "native", // Stage type, can be "native", "shell" or "redirect"
 | |
|     "flow_info": {
 | |
|         // Related flow information, mostly used for UI and surrounding elements
 | |
|         "title": "Welcome to authentik",
 | |
|         "background": "/static/dist/assets/images/flow_background.jpg",
 | |
|         "cancel_url": "/flows/-/cancel/"
 | |
|     },
 | |
|     // Main component to distinguish which stage is currently active
 | |
|     "component": "ak-stage-identification",
 | |
| 
 | |
|     // Stage-specific fields
 | |
|     "user_fields": ["username", "email"],
 | |
|     "password_fields": false,
 | |
|     "primary_action": "Log in",
 | |
|     "sources": []
 | |
| }
 | |
| ```
 | |
| 
 | |
| To respond to this challenge, send a response:
 | |
| 
 | |
| ## `POST /api/v3/flows/executor/test-flow/`
 | |
| 
 | |
| With this body
 | |
| 
 | |
| ```json
 | |
| {
 | |
|     // Component is required to determine how to parse the response
 | |
|     "component": "ak-stage-identification",
 | |
| 
 | |
|     // Stage-specific fields
 | |
|     "uid_field": "jens"
 | |
| }
 | |
| ```
 | |
| 
 | |
| Depending on the flow, you'll either get a 200 Response with another challenge, or a 302 redirect, which should be followed.
 | |
| 
 | |
| Depending also on the stage, a response might take longer to be returned (especially with the Duo Authenticator validation).
 | |
| 
 | |
| To see the data layout for every stage possible, see the [API Browser](./reference/flows-executor-get)
 | |
| 
 | |
| ## Result
 | |
| 
 | |
| If a stage with the component `ak-stage-access-denied` is returned, the flow has been denied.
 | |
| 
 | |
| If a stage with the component `xak-flow-redirect` is returned, the flow has been executed successfully.
 |