-
-
Notifications
You must be signed in to change notification settings - Fork 1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
website/integrations: Add documentation for Drupal #12925
base: main
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
@@ -0,0 +1,90 @@ | ||||||
--- | ||||||
title: Integrate with Drupal | ||||||
sidebar_label: Drupal | ||||||
--- | ||||||
|
||||||
# Integrate with Drupal | ||||||
|
||||||
<span class="badge badge--secondary">Support level: Community</span> | ||||||
|
||||||
## What is Drupal | ||||||
|
||||||
> [Drupal](https://new.drupal.org/home) is a free and open-source content | ||||||
> management system written in PHP and paired with a database. | ||||||
> | ||||||
> -- https://en.wikipedia.org/wiki/Drupal | ||||||
|
||||||
:::note | ||||||
There are many different modules for Drupal that allow you to set up SSO using | ||||||
different authentication methods. This tutorial uses the | ||||||
[OpenID Connect / OAuth client](https://www.drupal.org/project/openid_connect) | ||||||
module. | ||||||
::: | ||||||
|
||||||
## Preparation | ||||||
|
||||||
The following placeholders are used in this guide: | ||||||
|
||||||
- `drupal.ddev.site` is the FQDN of Drupal installation. | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Drupal can be selfhosted. As a result, it is not fair to say that drupal.ddev.site is it's FQDN. You could instead say |
||||||
- `authentik.company` is the FQDN of Authentik installation. | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. "authentik" should be in lowercase as per the style guide's "authentik names" section |
||||||
|
||||||
:::note | ||||||
This documentation lists only the settings that you need to change from their | ||||||
default values. Be aware that any changes other than those explicitly mentioned | ||||||
in this guide could cause issues accessing your application. | ||||||
::: | ||||||
|
||||||
|
||||||
## authentik configuration | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Note to tana: reminder: will update format in a later PR |
||||||
|
||||||
### Provider | ||||||
|
||||||
- Go to Applications -> Providers | ||||||
https://authentik.company/if/admin/#/core/providers | ||||||
- Create an OAuth2/OpenID Provider | ||||||
- Set the Authentication flow to default-authentication-flow | ||||||
- The Authorisation flow can be either default-provider-authorization-implicit-consent | ||||||
or default-provider-authorization-explicit-consent | ||||||
- Set the Client type to "Confidential" | ||||||
- Note the Cliend ID and Client Secret | ||||||
- Set the Redirect URIs/Origins to your Drupal site | ||||||
https://drupal.ddev.site/openid-connect/generic | ||||||
- Leave everything else as-is | ||||||
|
||||||
### Application | ||||||
|
||||||
- Go to Applications -> Applications | ||||||
https://authentik.company/if/admin/#/core/applications | ||||||
- Create an application e.g. "Drupal" and set the Provider field to the provider | ||||||
created above | ||||||
|
||||||
### 2FA (optional) | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This section is not needed |
||||||
|
||||||
- Go to Flows & Stages -> Flows | ||||||
- Open the default-authentication-flow (click the link with the flow name, not | ||||||
the edit button) | ||||||
- Go to "Stage Bindings" | ||||||
- Edit default-authentication-mfa-validation | ||||||
- Select "TOTP Authenticators" in "Device classes" and | ||||||
"default-authenticator-totp-setup (TOTP Authenticator Setup Stage" in | ||||||
"Configuration stages" | ||||||
data:image/s3,"s3://crabby-images/9f551/9f5518ad5dc29ba9477ef11dcb6abae9d3603773" alt="" | ||||||
|
||||||
## Service configuration | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Please see the style guide's "formatting" section for proper URL styling There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. "x endpoint" & "if authentik is running locally [...]" lines could be consolidated into one, potentially with a message at the top of this configuration. I suggest looking at the style guide's admonitions syntax section for the correct markdown format. |
||||||
|
||||||
- Go to https://drupal.ddev.site/admin/config/services/openid-connect | ||||||
- Input the Client ID and Secret you noted above | ||||||
- Fill out the following endpoints: | ||||||
- Authorization endpoint: https://authentik.company/application/o/authorize/ | ||||||
- Token endpoint: https://authentik.company/application/o/token/ | ||||||
if Authentik is running locally, use http://host.docker.internal:9000/application/o/token/ | ||||||
- UserInfo endpoint: https://authentik.company/application/o/userinfo/ | ||||||
if Authentik is running locally, use http://host.docker.internal:9000/application/o/userinfo/ | ||||||
- Select the "Override registration settings" checkbox | ||||||
- Enable the OpenID button on user login form | ||||||
|
||||||
## Configuration verification | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The configuration verification section is a step to confirm that authentik works with the service. You need to explicitly mention how to log in & if there are any particularities. I suggest looking at the Integration template's example for a good base |
||||||
Once logged in for the first time, depending on your user registration settings | ||||||
you may get a message saying you've successfully logged in but your account is | ||||||
blocked and needs to be approved by an administrator, so unblock the user in the | ||||||
usual way, and then you can log in successfully. | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
How? Could you link documentation which references this unblock method? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You shouldn't link Drupal's home page in markdown and link it's wikipedia page right below. Please only keep Line 15