Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
For protecting your apps using Traefik as the reverse proxy, please see our guide on Traefik here
Copy the data in NGINX Config - Authelia and head to your NPM dashboard > Hosts > Proxy Hosts
Select Add Proxy Host
Details:
Domain name: auth.example.com (or whatever CNAME you set in your DNS for Authelia)
Scheme: http
Forward Hostname / IP: Name of your Authelia container (must be on the same custom docker network as NPM, otherwise use server IP)
Port: 9091
Turn ON: Cache Assets, Block Common Exploits
SSL:
Request new SSL certificate
Turn ON: Force SSL, HTTP/2 Support, HSTS Enabled (if using, i.e. in Cloudflare)
Email address: used to create Let’s Encrypt cert.
Select I Agree and Save.
Alternatively, see our guide on using Cloudflare Origin Certs
Test that you can reach the WebUI of Authelia selecting the new proxy or typing in its address. i.e. 'auth.example.com'
If all the above is working as intended; Edit proxy host 'auth.example.com'
Advanced
Under Custom Nginx Configuration, paste the config you customized from NGINX Config - Authelia
Save and confirm you can still access the WebUI via the URL.
Edit proxy host 'sonarr.example.com'
Advanced
Under Custom Nginx Configuration, paste the config from NGINX Config - Endpoint and customize as necessary.
(Optional) Now that Authelia is acting as your single sign-on security you can now disable any in-app security/logins. Disabling the in-app login will still be secure as Authelia will be protecting it but will prevent you from having to log in twice for every app and remember all of the usernames and passwords etc.
In your appdata/authelia folder you will find configuration.yml
You MUST edit this file to suit your environment. We strongly suggest you watch our video along with this guide to help you understand how it all works.
The sample provided in this guide has been tested and verified to work, however, it is strongly advised to read the official docs on the configuration to ensure it meets your requirements (https://www.authelia.com/docs/configuration/)
For secret keys, you can create a 128-bit encryption key to put in from here: https://www.allkeysgenerator.com/Random/Security-Encryption-Key-Generator.aspx Remember to keep them different for the different areas which use them.
You have two options when deciding how you want users to exist for Authelia.
Option 1 - Using a simple YML file with the user's encrypted credentials that Authelia can read.
Option 2 - Allow Authelia to read from an LDAP database such as FreeIPA or Active Directory.
NOTE
The choice is yours, however, keep in mind that only one option can be used.
Decide which option works for you and make the edits in the configuration.yml, under the "authentication_backend
" section, by commenting out the option you do not want to use.
In the sidebar, you will find the file named 'users_database.yml'.
Copy the file content into appdata/authelia/users_database.yml.
You MUST edit this file.
Adjust the file to the user you would like to sign in as. For help see here: https://www.authelia.com/docs/configuration/authentication/file.html
Changes include the username and display name, for example.
To generate the hashed password, open the terminal in Unraid
Type in the following (replacing 'yourpassword' with the password you want for the user):
Copy the hashed password that is generated and paste it into the users_database.yml file as replacing the one in the template we provide.
Remember to comment out the 'ldap'
section in your configuration.yml since you are not using it.
If you prefer to use an LDAP database to read users from, you can do so by using the LDAP configuration in the sidebar.
Choose the type of LDAP you are using (i.e OpenLDAP, Active Directory or FreeIPA). We have a video guide on creating a FreeIPA server here and also a video on how to set up OpenLDAP here. --ADD-LINK-TO-VIDEO-HERE--
Edit the contents to suit your environment, where necessary
Replace the LDAP section in the Authelia configuration.yml with the new one
Remember to comment out the 'file
' section, since you are not using the users_database.yml file.
Want to see an OpenLDAP and phpLDAPadmin section here? Let us know in Discord or in the video description!
At this point, you should start the Authelia container and read the logs.
Test that you can reach the WebUI of Authelia (http://SERVERIP:9091) and can log in or set up 2FA.
The rules section in the Authelia configuration file have some important notes to consider:
Rules are read by Authelia from top to bottom
Therefore, you should practice putting the most restrictive rules last.
A catch-all wildcard rule at the very end will safeguard you by applying a default policy on anything you have enabled Authelia on, without needing a specific rule.
There may be times when you want to allow certain apps to be covered by single-factor authentication, and others to be covered by two-factor authentication.
You can specify the user, groups, or both that can access a particular resource.
You can restrict access to a particular subfolder of a URL rather than the entire URL. For example, if you want to protect the Admin page of an application but not the main page itself.
You may have a combination of all the above if you so choose.
For a more in-depth look at access control, please see the official Authelia docs here.
WARNING
Below you will find a comprehensive list to read through as an example. This is a valid and working example, however, we do not recommend blindly copying it without fully understanding what the rules are doing.
For a more in-depth look at access control, please see the official Authelia docs here.
In the above, you may notice that certain rules are allowing API endpoints. This is important when you want to protect an application that uses API communications to send and receive data and do not want it to be hindered by Authelia.
A classic example is Sonarr or Radarr. These applications need the API to talk to other applications and since they are unable to 'sign in' to Authelia themselves, we need to tell Authelia that:
We want to protect sonarr.domain.com with Authelia
However, we want to bypass Authelia for traffic coming in and out of the API endpoint of Sonarr
Here's how that would look (extracted from the example above):
Again, remember the hierarchy. We want the bypass to be above any restrictive rules so that Authelia knows that bypassing this endpoint comes first.
If you are using FreeIPA LDAP, use this in your configuration.yml instead of the file authentication.
This config is using the 'authelia' user - so you will need to create one in FreeIPA
Additionally read through this config and everywhere you see 'dc=domain' be sure to update that with your site - aka ibracorp as the apex domain for ibracorp.io -- i SUSPECT that you would need to adjust the 'dc=com' to dc=org or dc=io pending your top level domain
If you are using Microsoft Active Directory LDAP, use this in your configuration YML
If you are not using LDAP, use this for the `users_database.yml`
If you are using LLDAP / Light LDAP, use this in your configuration YML.
Authelia / Sycotix's Repository / Security
File editors such as Notepad++ or Code-Server
Domain with the following subdomains
NOTE: You may change these but keep in mind you must adapt it throughout the guide. (app.example.com is simply any app you want to protect with Authelia, i.e. sonarr.example.com).
example.com
auth.example.com
app.example.com
We strongly suggest using Code-Server to help you edit your configuration files and validate everything is correctly formatted.
YAML is extremely sensitive, and Code-Server, along with the YAML plugin, can be extremely helpful to save a lot of time troubleshooting. (Trust us, we've been helping members with Authelia for over a year!)
You can follow our guide here.
Redis is an in-memory data structure store, used as a distributed, in-memory key-value database, cache, and message broker, with optional durability.
In Unraid, visit the apps tab
Search for and install 'redis'. We are using the container from A75G's Repository
which uses the Bitnami Redis image.
It has parameters mapped for a password, which we will need to add into configuration.yml later.
In the template installation screen:
Set the custom docker network
Set a strong password (it will be used by Authelia later)
Add the appdata path as per the below
IMPORTANT
The default template does not have a mapping for the appdata storage. Without this, Redis will not be able to cache your data and the 'Remember Me' option in Authelia will not work.
In the template, click "Add another Path, Port, Variable, Label or Device" and add the following path:
Container Path: /bitnami/
Host Path: /mnt/user/appdata/redis/bitnami/
IMPORTANT
Change the permissions of the redis folder with the following command executed in the webterminal: chmod -R 777 /mnt/user/appdata/redis/*
If you do not already have MariaDB installed, then follow the next 3 steps. If you already have MariaDB installed then skip to the next section where you will create the database for Authelia.
In Unraid, visit the apps tab
Search for and install 'mariadb'. We are using the linuxserver/mariadb container.
In the template installation screen:
Set the custom docker network
Set a strong password
Once installed, follow these steps to create our user and database for Authelia.
If you want a GUI option to create, manage and administer databases, we recommend using Adminer. You can find our guide on that here.
Follow our Adminer + MariaDB guide to use a GUI to help you manage databases in an easy way.
If you want to use the command-line to create the database then please do the following:
Under the Docker tab in Unraid, left-click the MariaDB container, select Console
Create our user:
Enter the following then hit enter:
Enter the password you set in the container settings then type:
This password will be referenced in the Authelia configuration.yml
Create our database:
Enter the following then hit enter:
Allow privileges to the database:
Enter the following then hit enter:
This is the password you created for the user above.
Enter the following then hit enter:
You can now close the terminal window
Head to the Community Applications store in Unraid
Search for and click to install Authelia
from Sycotix's Repository
If you are using a custom Docker network, select it in the 'Network Type' field.
Enter the host port you want to map for the WebUI. By default it is 9091
. Only change it if this port is already in use.
Click Apply and wait for the container to pull down and start.
NOTE
The container will immediately shut down due to no configuration. This is normal and you can leave it off for now.
In this Authelia setup I will be configuring Authelia to have local authentication and it enforces Smart Card authentication via WedAuthn for secure remote access
This guide is created with the help of Florian Mullers guide that can be found here and has been modified with improvements
Run the below command in the UnRAID console and save the output somewhere safe, we will need these later. Put the random string/ key in a file in plain text on the first line.
Create JWT Secret and save it in /mnt/user/appdata/Authelia/secrets/jwtsecret
Create Session Secret and save it in /mnt/user/appdata/Authelia/secrets/session
Storage Encryption Key and save it in /mnt/user/appdata/Authelia/secrets/storage
MariaDB Password and save it in /mnt/user/appdata/Authelia/secrets/mariadb
SMTP Password and save it in /mnt/user/appdata/Authelia/secrets/smtp
OIDC HMAC Secret and save it in /mnt/user/appdata/Authelia/secrets/oidcsecret
OIDC Private Key
We need to map each of the secret files we created above and map them to an environment variable. You can find a list of all Authelia Environment Variables here
Create the below variables on the Authelia Docker container for all the secrets required. This removes the need for them to be in your configuration.yml file for more security
Once all Environment Variables are correct, your UnRAID configuration should look like the below
This guide assumes you have Authelia, Redis and SQL already running and the site is accessible from auth.<domain-name>
We will now be doing the advanced configuration to get OpenID Connect and WebAuthn working securely. We will be utilising Docker Enviroment Variables to input our Certificates, Secrets and Tokens for this
Refer to the OIDC - configuration.yml page for a copy of our Authelia configuration file. Please input your Authelia domain name, SMTP server and OIDC Shared Secret NOTE: OIDC Shared Secret is not working as a Environemnt Variable in Authelia v4.37.5 and needs to be put directly into the configuration.yml file in plain text
Create a OIDC Shared Secret, this will be shared with Cloudflare for OIDC to function.
Replace the <OIDC Secret> in the configuration.yml file with the string generated above
Authelia should now succesfully boot, if there is an error check the logs and troubleshoot
Note: Host lines may need to be updated to match the exact name of your container if you do not have the same as whats in the example file. Alternatively you can also you the IP for the service instead. See below for examples of alternative setups.
For access control rule examples such as API request bypass, head to the Rules page.
To have you login format inserted automatically we can edit the ldapadmin config.php file located at /opt/appdata/openldap/admin/config/config.php
and adding in the following lines below to the end of the config file to automatically fill in out login information as below:
OpenID Connect is an authentication protocol that works with the OAuth2.0 framework. This protocol allows the use of Single Sign On (SSO) for sites that support OIDC Providers
This configuration drops the need for Traekfik or Nginx Proxy Manager and is completely managed by Cloudflare Zero Trust and their Cloudflared Tunnel (HTTPs/ QUIC Protocol)
At the end of this you will be able to securely access your HTTP, SSH and RDP session remotely via Cloudflare anywhere in the world
UnRAID
Domain name registered with Cloudflare
Cloudflared Tunnel running (not legacy Argo Tunnel)
NO Traefik or Nginx Proxy Manager needed
Our work sometimes takes months to research and develop. If you want to help support us, please consider:
Liking and Subscribing to our YouTube channel
Joining our Discord server
Becoming a paid member on our IBRACORP website
Donating via PayPal
OpenLDAP is a free, open-source implementation of the Lightweight Directory Access Protocol developed by the OpenLDAP Project.
Writer / Producer
Hawks
Contributor
Sycotix
Inspiration
TrueCharts
Testing / Proofreading
DiscDuck, Sycotix
We hope you enjoyed this guide. It was conceptualized, written, and implemented by our Admin Hawksy.
Our work sometimes takes months to research and develop. If you want to help support us, please consider:
Liking and Subscribing to our YouTube channel
Joining our Discord server
Becoming a paid member on our IBRACORP website
Donating via PayPal
Cloudflare Zero Trust allows users to register their own Single Sign On (SSO) provider by utilising the OpenID Connect Protocol
Login to Cloudflare Zero Trust Portal and open Settings > Authentiation > Add New
Select OpenID Connect and input the below values
Name: Authelia
App ID: authelia
Client Secret: <OIDC Secret>
Auth URL: https://auth.<domain-name>/api/oidc/authorization
Token URL: https://auth.<domain-name>/api/oidc/token
Certificate URL: https://auth.<domain-name>/jwks.json
Once Authelia is running and Cloudflare is enabled. Click Test and attempt to login
This page has a few extra steps to configure if wanted
I have enabled a few extra features in the Cloudflare Dashboard to disable the Cloudflare CDN Cache. I was noticing with cache enabled it was affecting certain applications
I have enforced Full (Strict) SSL Encryption. This can be done under SSL/TLS > Overview
Under SSL/TLS > Edge Certificates, I have enabled the below
Always use HTTPS: Enabled
HTTP Strict Transport Security (HSTS): Enabled
Minimum TLS Version: TLS 1.3
Automatic HTTPS Rewrites: Enabled
Utilising Cloudflare WAF (Web Application Firewall) I have only allowed connections originating from Australia access. This drastically reduced connections to my site and improved security
Cloudflare Tunnel and Cloudflare Zero Trust go hand in hand. This is the secure tunnel into your network and the mechanism that will allow you secure remote access
To run a Cloudflare Tunnel from UnRAID you will need to manually create the docker container.
Name: Cloudflared Tunnel
Repository: cloudflare/cloudflared:latest
Post Arguments: tunnel --no-autoupdate run --token <tunnel-token>
Icon URL: Any Icon URL you like
Your Tunnel Token can be found by creating a Tunnel within Cloudflare Zero Trust > Access > Tunnels. The token is provided in the docker run command
Once the container is running it will grab it's configuration automatically from Cloudflare and also make 4x seperate TCP/443 connections outbound using the QUIC protocol. The Cloudflare Tunnel should now have a status of "HEALTHY"
Cloudflare access is a product within Cloudflare Zero Trust. Access allows us to share HTTP, SSH and RDP session securely via the Cloudflare Tunnel
Head to Cloudflare Zero Trust > Access > Tunnels > "your tunnel" > Configure > Public Hostname and click Add a public hostname
This configuration is letting our Cloudflare Tunnel know how to route to our Authelia instance in our network. Authelia in my network is listening on https://192.168.0.2:9091 and has a self-signed SSL certificate
Subdomain: auth.<domain-name>
Service: HTTP or HTTPS
URL: IP Address & Port Authelia is listening
NoTLSVerify: Enable this if you are using a self-signed SSL certificate as Cloudflare only trust their own root certificates
Once saved Cloudflare will automatically push this configuration to your Cloudflare Tunnel and it will immediately be accessible via the specifed domain name
auth.<domain-name> is accessible via the internet and has a valid SSL certificate
We have now configured remote access to our Authelia application hosted on UnRAID
auth.<domain-name> must be accessible by any device needing to authenticate via OIDC
This is the only site not protected via Zero Trust
We can create Cloudflare Page Rules to restrict IP Addresses, Countries and others from accessing this site
If you are using OpenLDAP, use this in your configuration.yml instead of the file authentication.
First, follow the guide here if you have not done so already.
In your configuration.yml, now replace the file/LDAP section with the below and fill in the details accordingly, remembering to replace domain
with your domain details. If you are running the openldap
container outside the docker network, you will have to replace openldap
in the url
section for the openldap
container IP.
Source - https://www.authelia.com/docs/configuration/authentication/ldap.html#configuration
In your appdata/Authelia folder, you will find configuration.yml
You MUST edit this file to suit your environment. We strongly suggest you watch our Authelia video before following along with this guide to help you understand how it all works. Make sure to use the OpenLDAP settings for your configuration.yml to work with this guide.
The sample provided in this guide has been tested and verified to work. However, it is strongly advised to read the official docs on the configuration to ensure it meets your requirements (https://www.authelia.com/docs/configuration/)
For secret keys, you can create a 128-bit encryption key to put in from here: https://www.allkeysgenerator.com/Random/Security-Encryption-Key-Generator.aspx Remember to keep them different for the different areas which use them.
Here we are going to use the following format for the login credentials, make sure to replace domain with your domain. Add your password we created in the docker compose file and then click “Authenticate”.
Now we will create the admin group for users. You can repeat these steps to create whatever group you like. You can then later use these groups to refine rules within the Authelia configuration.yml file.
First, we will create the organizational unit. This is where all the groups will be stored. Select your domain in the left panel and some options will appear in the right panel.
Choose “Create a child entry”.
We can now select “Generic: Organizational Unit”.
We will call this organizational unit “Groups”.
Click “Create Object” and then “Commit” to save the settings. You can now see the organizational unit of groups has created.
Now that we have the category of Groups, we will create our first group of “admins”. This is where we will add our first user too. This time, instead of selecting the top domain, we will be selecting the “groups” tab.
As before, we will now see some more options in the right-hand pane. We will select to “Create a child entry” within the groups section.
This time we will be creating a “Generic: Posix Group”.
Once you have selected this, we will type in our group name. For this example, we will use the group “admins” as our first group.
Now click Create Object and Commit. You will see in the left-hand side under groups that the group “admins” has now created.
Below, we will add our first user to the organization. We will also add this user to the admins group. You can repeat this process to create as many users as you like.
Select the top-level domain.
On the right-hand side, choose to create another child entry.
Same as with the “groups”, we created, we are going to create another organizational unit.
This time we will call it “Users”. This will be where we will store all of our users that we add to the organization.
Click Create Object and Commit. You will now see this added to the tree under the main domain. Click this newly created Users tab.
Select to create a child entry under the Users organizational unit.
This time, we will add the “Generic: User Account”.
Here we will fill in all the details about the user. Make sure to use all lower case for the “User ID”, this allows the username field to be case-insensitive when logging in via Authelia. When selecting the crypt for the password, choose the sha256crypt
for better security. Under GID Number, we will be selecting the group to add the user too, for our first user we will be adding them to the “admins” group we just created.
Now select Create Object and Commit.
You have now added your first user. To utilize the “Forgot password” feature of Authelia, we can also add more attribute fields to the user. For this feature, we will need the user's email added to the user record. Click “Add new attribute”.
On the dropdown, choose "Email".
Add the user's email and the click “Update Object”.
Click “update object” again to confirm. You have now added your new user to the admins group that you can use to log into Authelia.
Authelia is an open-source authentication and authorization server providing two-factor authentication and single sign-on (SSO) for your applications via a web portal.
Writer / Producer
Sycotix
Contributor
Hawks
Testing / Proofreading
DiscDuck, Hawks
Please read our disclaimer https://docs.ibracorp.io/#disclaimer.
Several second-factor methods:
Security Key (U2F) with Yubikey.
Mobile Push Notifications with Duo.
Password reset with identity verification using email confirmation.
Access restriction after too many invalid authentication attempts.
Fine-grained access control using rules which match criteria like subdomain, user, user group membership, request URI, the request method, and network.
The choice between one-factor and two-factor policies per-rule.
Support of basic authentication for endpoints protected by the one-factor policy.
Highly available using a remote database and Redis as a highly available KV store.
Compatible with Traefik out of the box using the ForwardAuth middleware.
Curated configuration from LinuxServer via their Swag container as well as a guide.
Kubernetes Support:
Compatible with the ingress-Nginx, the Traefik Kubernetes CRD, and the Traefik Kubernetes Ingress controllers out of the box.
Beta support for installing via Helm using our Charts.
Beta support for OpenID Connect.
To assist you in building your configuration, we have used frequent placeholders for you to easily find and replace with your own specific information. This allows a quick Find/Replace in your preferred text editor.
YOURPASSWORD - Password which you have set, with respect to the section you are reading. i.e. MySQL passwords should be different from your Redis password.
YOURSECRET - A secret 128-bit encryption key. You can use this site to generate them:
YOURDOMAIN - Your own domain name
SERVERIP - Local IP address of your host server. i.e. 192.168.1.50
CONTAINERPORT - Port the container is running on.
CONTAINERNAME - Name of the container to be proxied. i.e. 'monitorr'
CONTAINERIP - IP address of the container.
We hope you enjoyed this guide. It was conceptualized, written, and implemented by our Admin Sycotix.
Our work sometimes takes months to research and develop. If you want to help support us please consider:
Liking and Subscribing to our Youtube channel
Joining our Discord server
Becoming a paid member on our IBRACORP website
Donating via Paypal
Cloudflare Zero Trust allows users to register their own Single Sign On (SSO) provider by utilising the OpenID Connect Protocol. We can now protect our self hosted applications with Authelia
To reverse proxy an application behind Cloudflare Access. We need to create an "Application" within the Cloudflare Zero Trust dashboard
Naviagate to Access > Applications > Add an Application > Self-Hosted. Enter the domain name you wish the application to have. Cloudflare will automatically create the DNS Record
Follow the Policies and Authentication pages and set the settings you would like to configure for the specific application
Click Save
We now need to tell Cloudflare how to route to our self-hosted application. Navigate to Access > Tunnels > Tunnel-Name > Configure > Public Hostname > Add a Public Hostname
Once saved, Cloudflare will automatically push the configuration to our Tunnel and the site should be immediatelly accessible via Cloudflare Zero Trust and protected by Authelia via OpenID Connect
Use this config in the proxy settings of the app you want to protect
CAUTION
Remember to update this configuration with your specific configuration settings.
Placeholders here are:
SERVERIP (or container name if on the same )
YOURDOMAIN
This configuration is for local users and WebAuthn (FIDO2)
This configuration was created with the help of Florian Muller's excellent guide which can be viewed
Use this config in the Advanced Proxy settings of the Authelia proxy
CAUTION
Remember to update this configuration with your specific configuration settings.
Placeholders here are:
SERVERIP (or container name if on the same )