2017-09-03 06:25:43 +07:00
###############################################################
# Authelia configuration #
###############################################################
2017-01-22 23:54:45 +07:00
2019-12-07 03:45:59 +07:00
# The host and port to listen on
host : 0.0 .0 .0
2019-01-30 22:47:03 +07:00
port : 9091
2020-11-13 06:14:45 +07:00
# tls_key: /config/ssl/key.pem
2020-06-17 13:25:35 +07:00
# tls_cert: /config/ssl/cert.pem
2017-03-22 02:57:03 +07:00
2021-01-20 19:07:40 +07:00
# The theme to display: light, dark, grey
theme : light
2020-04-30 09:03:05 +07:00
# Configuration options specific to the internal http server
server :
# Buffers usually should be configured to be the same value.
# Explanation at https://docs.authelia.com/configuration/server.html
# Read buffer size configures the http server's maximum incoming request size in bytes.
read_buffer_size : 4096
# Write buffer size configures the http server's maximum outgoing response size in bytes.
write_buffer_size : 4096
2020-05-21 09:20:55 +07:00
# Set the single level path Authelia listens on, must be alphanumeric chars and should not contain any slashes.
path : ""
2020-04-30 09:03:05 +07:00
2019-12-07 03:45:59 +07:00
# Level of verbosity for logs: info, debug, trace
2020-03-10 02:57:53 +07:00
log_level : debug
2020-11-25 06:46:41 +07:00
# Format the logs are written as: json, text
# log_format: json
# File path where the logs will be written. If not set logs are written to stdout.
2020-11-13 06:14:45 +07:00
# log_file_path: /config/authelia.log
2017-01-23 00:18:19 +07:00
2019-04-25 04:52:08 +07:00
# The secret used to generate JWT tokens when validating user identity by
# email confirmation.
2020-04-23 08:11:32 +07:00
# JWT Secret can also be set using a secret: https://docs.authelia.com/configuration/secrets.html
2019-04-25 04:52:08 +07:00
jwt_secret : a_very_important_secret
2019-01-12 04:11:54 +07:00
# Default redirection URL
2017-10-18 04:24:02 +07:00
#
# If user tries to authenticate without any referer, Authelia
# does not know where to redirect the user to at the end of the
# authentication process.
# This parameter allows you to specify the default redirection
# URL Authelia will use in such a case.
#
# Note: this parameter is optional. If not provided, user won't
# be redirected upon successful authentication.
2017-11-03 03:34:07 +07:00
default_redirection_url : https://home.example.com:8080/
2017-10-18 04:24:02 +07:00
2020-03-25 08:48:20 +07:00
# TOTP Settings
2018-08-19 15:59:47 +07:00
#
2020-03-25 08:48:20 +07:00
# Parameters used for TOTP generation
2018-08-19 15:59:47 +07:00
totp :
2020-03-25 08:48:20 +07:00
# The issuer name displayed in the Authenticator application of your choice
# See: https://github.com/google/google-authenticator/wiki/Key-Uri-Format for more info on issuer names
2018-08-19 15:59:47 +07:00
issuer : authelia.com
2020-03-25 08:48:20 +07:00
# The period in seconds a one-time password is current for. Changing this will require all users to register
# their TOTP applications again.
# Warning: before changing period read the docs link below.
period : 30
# The skew controls number of one-time passwords either side of the current one that are valid.
# Warning: before changing skew read the docs link below.
skew : 1
# See: https://docs.authelia.com/configuration/one-time-password.html#period-and-skew to read the documentation.
2018-08-19 15:59:47 +07:00
2019-03-24 21:15:49 +07:00
# Duo Push API
#
# Parameters used to contact the Duo API. Those are generated when you protect an application
# of type "Partner Auth API" in the management panel.
duo_api :
2019-03-25 00:45:32 +07:00
hostname : api-123456789.example.com
2019-03-24 21:15:49 +07:00
integration_key : ABCDEF
2020-04-23 08:11:32 +07:00
# Secret can also be set using a secret: https://docs.authelia.com/configuration/secrets.html
2019-03-24 21:15:49 +07:00
secret_key : 1234567890abcdefghifjkl
2018-08-26 15:30:43 +07:00
# The authentication backend to use for verifying user passwords
# and retrieve information such as email address and groups
# users belong to.
2017-03-25 21:17:21 +07:00
#
2020-03-15 14:10:25 +07:00
# There are two supported backends: 'ldap' and 'file'.
2018-08-26 15:30:43 +07:00
authentication_backend :
2020-04-05 06:28:09 +07:00
# Disable both the HTML element and the API for reset password functionality
disable_reset_password : false
2020-05-05 02:39:25 +07:00
# The amount of time to wait before we refresh data from the authentication backend. Uses duration notation.
# To disable this feature set it to 'disable', this will slightly reduce security because for Authelia, users
# will always belong to groups they belonged to at the time of login even if they have been removed from them in LDAP.
# To force update on every request you can set this to '0' or 'always', this will increase processor demand.
# See the below documentation for more information.
# Duration Notation docs: https://docs.authelia.com/configuration/index.html#duration-notation-format
# Refresh Interval docs: https://docs.authelia.com/configuration/authentication/ldap.html#refresh-interval
refresh_interval : 5m
2018-08-26 15:30:43 +07:00
# LDAP backend configuration.
#
# This backend allows Authelia to be scaled to more
# than one instance and therefore is recommended for
# production.
ldap :
2020-11-27 16:59:22 +07:00
# The LDAP implementation, this affects elements like the attribute utilised for resetting a password.
# Acceptable options are as follows:
# - 'activedirectory' - For Microsoft Active Directory.
# - 'custom' - For custom specifications of attributes and filters.
# This currently defaults to 'custom' to maintain existing behaviour.
#
# Depending on the option here certain other values in this section have a default value, notably all
# of the attribute mappings have a default value that this config overrides, you can read more
# about these default values at https://docs.authelia.com/configuration/authentication/ldap.html#defaults
implementation : custom
2020-12-03 12:23:52 +07:00
# The url to the ldap server. Scheme can be ldap or ldaps in the format (port optional) <scheme>://<address>[:<port>].
2019-01-30 22:47:03 +07:00
url : ldap://127.0.0.1
2020-03-15 14:10:25 +07:00
2020-12-03 12:23:52 +07:00
# Use StartTLS with the LDAP connection.
start_tls : false
2021-01-04 17:28:55 +07:00
tls :
# Server Name for certificate validation (in case it's not set correctly in the URL).
# server_name: ldap.example.com
# Skip verifying the server certificate (to allow a self-signed certificate).
skip_verify : false
# Minimum TLS version for either Secure LDAP or LDAP StartTLS.
minimum_version : TLS1.2
2020-12-03 12:23:52 +07:00
# The base dn for every entries.
2018-08-26 15:30:43 +07:00
base_dn : dc=example,dc=com
2020-03-15 14:10:25 +07:00
2020-03-31 05:36:04 +07:00
# The attribute holding the username of the user. This attribute is used to populate
# the username in the session information. It was introduced due to #561 to handle case
# insensitive search queries.
# For you information, Microsoft Active Directory usually uses 'sAMAccountName' and OpenLDAP
# usually uses 'uid'
2020-04-16 06:46:51 +07:00
# Beware that this attribute holds the unique identifiers for the users binding the user and the configuration
# stored in database. Therefore only single value attributes are allowed and the value
# must never be changed once attributed to a user otherwise it would break the configuration
# for that user. Technically, non-unique attributes like 'mail' can also be used but we don't recommend using
# them, we instead advise to use the attributes mentioned above (sAMAccountName and uid) to follow
# https://www.ietf.org/rfc/rfc2307.txt.
2020-11-27 16:59:22 +07:00
# username_attribute: uid
2020-03-15 14:10:25 +07:00
2020-12-03 12:23:52 +07:00
# An additional dn to define the scope to all users.
2018-08-26 15:30:43 +07:00
additional_users_dn : ou=users
2020-03-15 14:10:25 +07:00
2020-03-31 05:36:04 +07:00
# The users filter used in search queries to find the user profile based on input filled in login form.
# Various placeholders are available to represent the user input and back reference other options of the configuration:
# - {input} is a placeholder replaced by what the user inputs in the login form.
2020-11-27 20:30:27 +07:00
# - {username_attribute} is a mandatory placeholder replaced by what is configured in `username_attribute`.
2020-03-31 05:36:04 +07:00
# - {mail_attribute} is a placeholder replaced by what is configured in `mail_attribute`.
# - DON'T USE - {0} is an alias for {input} supported for backward compatibility but it will be deprecated in later versions, so please don't use it.
#
2020-03-15 14:10:25 +07:00
# Recommended settings are as follows:
2020-03-31 05:36:04 +07:00
# - Microsoft Active Directory: (&({username_attribute}={input})(objectCategory=person)(objectClass=user))
# - OpenLDAP: (&({username_attribute}={input})(objectClass=person))' or '(&({username_attribute}={input})(objectClass=inetOrgPerson))
#
# To allow sign in both with username and email, one can use a filter like
2020-04-01 04:12:53 +07:00
# (&(|({username_attribute}={input})({mail_attribute}={input}))(objectClass=person))
2020-03-31 05:36:04 +07:00
users_filter : (&({username_attribute}={input})(objectClass=person))
2020-03-15 14:10:25 +07:00
2020-12-03 12:23:52 +07:00
# An additional dn to define the scope of groups.
2018-08-26 15:30:43 +07:00
additional_groups_dn : ou=groups
2020-03-15 14:10:25 +07:00
2020-03-31 05:36:04 +07:00
# The groups filter used in search queries to find the groups of the user.
# - {input} is a placeholder replaced by what the user inputs in the login form.
# - {username} is a placeholder replace by the username stored in LDAP (based on `username_attribute`).
# - {dn} is a matcher replaced by the user distinguished name, aka, user DN.
# - {username_attribute} is a placeholder replaced by what is configured in `username_attribute`.
# - {mail_attribute} is a placeholder replaced by what is configured in `mail_attribute`.
# - DON'T USE - {0} is an alias for {input} supported for backward compatibility but it will be deprecated in later versions, so please don't use it.
# - DON'T USE - {1} is an alias for {username} supported for backward compatibility but it will be deprecated in later version, so please don't use it.
2020-12-22 04:16:20 +07:00
# If your groups use the `groupOfUniqueNames` structure use this instead: (&(uniquemember={dn})(objectclass=groupOfUniqueNames))
2018-08-26 15:30:43 +07:00
groups_filter : (&(member={dn})(objectclass=groupOfNames))
2020-05-05 02:39:25 +07:00
2018-08-26 15:30:43 +07:00
# The attribute holding the name of the group
2020-11-27 16:59:22 +07:00
# group_name_attribute: cn
2020-05-05 02:39:25 +07:00
2020-04-16 06:46:51 +07:00
# The attribute holding the mail address of the user. If multiple email addresses are defined for a user, only the first
# one returned by the LDAP server is used.
2020-11-27 16:59:22 +07:00
# mail_attribute: mail
2020-05-05 02:39:25 +07:00
2020-06-19 17:50:21 +07:00
# The attribute holding the display name of the user. This will be used to greet an authenticated user.
2020-11-27 16:59:22 +07:00
# display_name_attribute: displayname
2020-06-19 17:50:21 +07:00
2018-08-26 15:30:43 +07:00
# The username and password of the admin user.
user : cn=admin,dc=example,dc=com
2020-04-23 08:11:32 +07:00
# Password can also be set using a secret: https://docs.authelia.com/configuration/secrets.html
2018-08-26 15:30:43 +07:00
password : password
2017-09-03 03:38:26 +07:00
2019-01-12 04:11:54 +07:00
# File backend configuration.
2018-08-26 15:30:43 +07:00
#
# With this backend, the users database is stored in a file
# which is updated when users reset their passwords.
2019-01-12 04:11:54 +07:00
# Therefore, this backend is meant to be used in a dev environment
2018-08-26 15:30:43 +07:00
# and not in production since it prevents Authelia to be scaled to
2020-04-11 10:54:18 +07:00
# more than one instance. The options under 'password' have sane
2020-03-06 08:38:02 +07:00
# defaults, and as it has security implications it is highly recommended
# you leave the default values. Before considering changing these settings
# please read the docs page below:
# https://docs.authelia.com/configuration/authentication/file.html#password-hash-algorithm-tuning
2018-08-26 15:30:43 +07:00
#
2019-01-12 04:11:54 +07:00
## file:
2020-06-17 13:25:35 +07:00
## path: /config/users_database.yml
2020-04-11 10:54:18 +07:00
## password:
2020-03-06 08:38:02 +07:00
## algorithm: argon2id
## iterations: 1
## key_length: 32
## salt_length: 16
2020-03-06 15:40:56 +07:00
## memory: 1024
2020-03-06 08:38:02 +07:00
## parallelism: 8
2017-03-25 21:17:21 +07:00
# Access Control
#
2018-10-24 05:29:09 +07:00
# Access control is a list of rules defining the authorizations applied for one
# resource to users or group of users.
2017-03-25 21:17:21 +07:00
#
2020-03-15 14:10:25 +07:00
# If 'access_control' is not defined, ACL rules are disabled and the 'bypass'
2019-01-12 04:11:54 +07:00
# rule is applied, i.e., access is allowed to anyone. Otherwise restrictions follow
2017-09-03 20:22:09 +07:00
# the rules defined.
2018-10-24 05:29:09 +07:00
#
# Note: One can use the wildcard * to match any subdomain.
2019-01-12 04:11:54 +07:00
# It must stand at the beginning of the pattern. (example: *.mydomain.com)
2018-10-24 05:29:09 +07:00
#
2019-01-12 04:11:54 +07:00
# Note: You must put patterns containing wildcards between simple quotes for the YAML
2020-01-21 07:10:00 +07:00
# to be syntactically correct.
2017-09-03 20:22:09 +07:00
#
2020-03-15 14:10:25 +07:00
# Definition: A 'rule' is an object with the following keys: 'domain', 'subject',
# 'policy' and 'resources'.
2018-10-24 05:29:09 +07:00
#
2020-03-15 14:10:25 +07:00
# - 'domain' defines which domain or set of domains the rule applies to.
2017-09-03 20:22:09 +07:00
#
2020-03-15 14:10:25 +07:00
# - 'subject' defines the subject to apply authorizations to. This parameter is
2018-10-24 05:29:09 +07:00
# optional and matching any user if not provided. If provided, the parameter
# represents either a user or a group. It should be of the form 'user:<username>'
# or 'group:<groupname>'.
#
2020-03-15 14:10:25 +07:00
# - 'policy' is the policy to apply to resources. It must be either 'bypass',
# 'one_factor', 'two_factor' or 'deny'.
2018-10-24 05:29:09 +07:00
#
2020-03-15 14:10:25 +07:00
# - 'resources' is a list of regular expressions that matches a set of resources to
2019-01-12 04:11:54 +07:00
# apply the policy to. This parameter is optional and matches any resource if not
2018-10-24 05:29:09 +07:00
# provided.
2017-03-26 00:42:48 +07:00
#
2018-10-24 05:29:09 +07:00
# Note: the order of the rules is important. The first policy matching
# (domain, resource, subject) applies.
2017-03-25 21:17:21 +07:00
access_control :
2020-03-15 14:10:25 +07:00
# Default policy can either be 'bypass', 'one_factor', 'two_factor' or 'deny'.
2018-10-24 05:29:09 +07:00
# It is the policy applied to any resource if there is no policy to be applied
# to the user.
2017-09-03 20:22:09 +07:00
default_policy : deny
2021-01-04 17:55:23 +07:00
networks :
- name : internal
networks :
- 10.10 .0 .0 /16
- 192.168 .2 .0 /24
- name : VPN
networks : 10.9 .0 .0 /16
2018-10-24 05:29:09 +07:00
rules :
# Rules applied to everyone
2017-11-03 03:34:07 +07:00
- domain : public.example.com
2019-03-04 05:51:52 +07:00
policy : bypass
2019-03-28 05:09:01 +07:00
- domain : secure.example.com
policy : one_factor
# Network based rule, if not provided any network matches.
networks :
2021-01-04 17:55:23 +07:00
- internal
- VPN
2019-03-28 05:09:01 +07:00
- 192.168 .1 .0 /24
2021-01-04 17:55:23 +07:00
- 10.0 .0 .1
2020-04-16 07:18:11 +07:00
- domain :
- secure.example.com
- private.example.com
2018-10-23 04:21:17 +07:00
policy : two_factor
2019-03-28 05:09:01 +07:00
2019-03-04 05:51:52 +07:00
- domain : singlefactor.example.com
2018-10-23 04:21:17 +07:00
policy : one_factor
2018-10-24 05:29:09 +07:00
2019-11-30 23:49:52 +07:00
# Rules applied to 'admins' group
- domain : "mx2.mail.example.com"
2019-12-04 14:46:49 +07:00
subject : "group:admins"
2018-10-24 05:29:09 +07:00
policy : deny
2020-04-16 07:18:11 +07:00
2019-11-30 23:49:52 +07:00
- domain : "*.example.com"
2020-04-16 07:18:11 +07:00
subject :
- "group:admins"
- "group:moderators"
2018-10-24 05:29:09 +07:00
policy : two_factor
# Rules applied to 'dev' group
- domain : dev.example.com
resources :
2019-11-30 23:49:52 +07:00
- "^/groups/dev/.*$"
subject : "group:dev"
2018-10-24 05:29:09 +07:00
policy : two_factor
# Rules applied to user 'john'
- domain : dev.example.com
resources :
2019-11-30 23:49:52 +07:00
- "^/users/john/.*$"
subject : "user:john"
2018-10-24 05:29:09 +07:00
policy : two_factor
# Rules applied to user 'harry'
- domain : dev.example.com
resources :
2019-11-30 23:49:52 +07:00
- "^/users/harry/.*$"
subject : "user:harry"
2018-10-24 05:29:09 +07:00
policy : two_factor
# Rules applied to user 'bob'
2019-11-30 23:49:52 +07:00
- domain : "*.mail.example.com"
subject : "user:bob"
2018-10-24 05:29:09 +07:00
policy : two_factor
2019-11-30 23:49:52 +07:00
- domain : "dev.example.com"
2018-10-24 05:29:09 +07:00
resources :
2019-11-30 23:49:52 +07:00
- "^/users/bob/.*$"
subject : "user:bob"
2018-10-24 05:29:09 +07:00
policy : two_factor
2017-03-25 21:17:21 +07:00
2017-03-16 05:07:57 +07:00
# Configuration of session cookies
2018-10-24 05:29:09 +07:00
#
2017-09-03 06:25:43 +07:00
# The session cookies identify the user once logged in.
2017-01-22 23:54:45 +07:00
session :
2018-08-19 18:07:00 +07:00
# The name of the session cookie. (default: authelia_session).
name : authelia_session
2020-03-28 13:10:39 +07:00
# The secret to encrypt the session data. This is only used with Redis.
2020-04-23 08:11:32 +07:00
# Secret can also be set using a secret: https://docs.authelia.com/configuration/secrets.html
2020-04-04 06:11:33 +07:00
secret : insecure_session_secret
2018-10-24 05:29:09 +07:00
2019-12-06 15:59:32 +07:00
# The time in seconds before the cookie expires and session is reset.
2020-04-05 19:37:21 +07:00
expiration : 1h
2017-09-03 06:25:43 +07:00
2019-12-06 15:59:32 +07:00
# The inactivity time in seconds before the session is reset.
2020-04-05 19:37:21 +07:00
inactivity : 5m
2017-10-17 05:38:10 +07:00
2020-04-04 06:11:33 +07:00
# The remember me duration.
# Value of 0 disables remember me.
2020-04-05 19:37:21 +07:00
# Value is in seconds, or duration notation. See: https://docs.authelia.com/configuration/index.html#duration-notation-format
2020-04-04 06:11:33 +07:00
# Longer periods are considered less secure because a stolen cookie will last longer giving attackers more time to spy
# or attack. Currently the default is 1M or 1 month.
remember_me_duration : 1M
2017-09-03 06:25:43 +07:00
# The domain to protect.
# Note: the authenticator must also be in that domain. If empty, the cookie
2018-10-24 05:29:09 +07:00
# is restricted to the subdomain of the issuer.
2017-11-03 03:34:07 +07:00
domain : example.com
2018-10-24 05:29:09 +07:00
2019-01-12 04:11:54 +07:00
# The redis connection details
2017-06-30 00:41:05 +07:00
redis :
2019-01-30 22:47:03 +07:00
host : 127.0 .0 .1
2017-06-30 00:41:05 +07:00
port : 6379
2020-12-16 07:31:39 +07:00
# Use a unix socket instead
2020-05-18 09:45:47 +07:00
# host: /var/run/redis/redis.sock
2020-04-23 08:11:32 +07:00
# Password can also be set using a secret: https://docs.authelia.com/configuration/secrets.html
2018-08-26 18:10:23 +07:00
password : authelia
2020-02-28 07:14:44 +07:00
# This is the Redis DB Index https://redis.io/commands/select (sometimes referred to as database number, DB, etc).
database_index : 0
2017-01-22 23:54:45 +07:00
2017-09-03 06:25:43 +07:00
# Configuration of the authentication regulation mechanism.
#
# This mechanism prevents attackers from brute forcing the first factor.
# It bans the user if too many attempts are done in a short period of
# time.
regulation :
2018-10-24 05:29:09 +07:00
# The number of failed login attempts before user is banned.
2018-07-08 22:02:28 +07:00
# Set it to 0 to disable regulation.
2017-09-03 06:25:43 +07:00
max_retries : 3
2019-01-12 04:11:54 +07:00
# The time range during which the user can attempt login before being banned.
2020-03-15 14:10:25 +07:00
# The user is banned if the authentication failed 'max_retries' times in a 'find_time' seconds window.
2020-04-05 19:37:21 +07:00
# Find Time accepts duration notation. See: https://docs.authelia.com/configuration/index.html#duration-notation-format
find_time : 2m
2017-09-03 06:25:43 +07:00
# The length of time before a banned user can login again.
2020-04-05 19:37:21 +07:00
# Ban Time accepts duration notation. See: https://docs.authelia.com/configuration/index.html#duration-notation-format
ban_time : 5m
2017-09-03 06:25:43 +07:00
# Configuration of the storage backend used to store data and secrets.
#
2020-02-01 19:54:50 +07:00
# You must use only an available configuration: local, mysql, postgres
2017-07-20 02:06:12 +07:00
storage :
# The directory where the DB files will be saved
2019-01-12 04:11:54 +07:00
## local:
2020-06-17 13:25:35 +07:00
## path: /config/db.sqlite3
2018-10-24 05:29:09 +07:00
2019-11-17 02:50:58 +07:00
# Settings to connect to MySQL server
mysql :
2019-11-16 17:38:21 +07:00
host : 127.0 .0 .1
port : 3306
2018-03-29 05:04:59 +07:00
database : authelia
2019-11-16 17:38:21 +07:00
username : authelia
2020-04-23 08:11:32 +07:00
# Password can also be set using a secret: https://docs.authelia.com/configuration/secrets.html
2019-11-16 17:38:21 +07:00
password : mypassword
2019-11-17 02:50:58 +07:00
2020-04-11 09:38:57 +07:00
# Settings to connect to PostgreSQL server
2019-11-17 02:50:58 +07:00
# postgres:
# host: 127.0.0.1
2020-04-11 09:38:57 +07:00
# port: 5432
2019-11-17 02:50:58 +07:00
# database: authelia
# username: authelia
2020-04-23 08:11:32 +07:00
# # Password can also be set using a secret: https://docs.authelia.com/configuration/secrets.html
2019-11-17 02:50:58 +07:00
# password: mypassword
2020-04-23 08:11:32 +07:00
# sslmode: disable
2017-01-29 01:59:15 +07:00
2017-09-03 06:25:43 +07:00
# Configuration of the notification system.
#
2017-03-16 05:07:57 +07:00
# Notifications are sent to users when they require a password reset, a u2f
# registration or a TOTP registration.
[FEATURE] Notifier Startup Checks (#889)
* implement SMTP notifier startup check
* check dial, starttls, auth, mail from, rcpt to, reset, and quit
* log the error on failure
* implement mock
* misc optimizations, adjustments, and refactoring
* implement validate_skip config option
* fix comments to end with period
* fix suites that used smtp notifier without a smtp container
* add docs
* add file notifier startup check
* move file mode into const.go
* disable gosec linting on insecureskipverify since it's intended, warned, and discouraged
* minor PR commentary adjustment
* apply suggestions from code review
Co-Authored-By: Amir Zarrinkafsh <nightah@me.com>
2020-04-21 11:59:38 +07:00
# Use only an available configuration: filesystem, smtp.
2017-01-22 23:54:45 +07:00
notifier :
[FEATURE] Notifier Startup Checks (#889)
* implement SMTP notifier startup check
* check dial, starttls, auth, mail from, rcpt to, reset, and quit
* log the error on failure
* implement mock
* misc optimizations, adjustments, and refactoring
* implement validate_skip config option
* fix comments to end with period
* fix suites that used smtp notifier without a smtp container
* add docs
* add file notifier startup check
* move file mode into const.go
* disable gosec linting on insecureskipverify since it's intended, warned, and discouraged
* minor PR commentary adjustment
* apply suggestions from code review
Co-Authored-By: Amir Zarrinkafsh <nightah@me.com>
2020-04-21 11:59:38 +07:00
# You can disable the notifier startup check by setting this to true.
disable_startup_check : false
2017-10-09 03:48:20 +07:00
# For testing purpose, notifications can be sent in a file
2018-08-26 15:30:43 +07:00
## filesystem:
2020-06-17 13:25:35 +07:00
## filename: /config/notification.txt
2017-10-09 03:48:20 +07:00
2019-12-30 09:03:51 +07:00
# Use a SMTP server for sending notifications. Authelia uses PLAIN or LOGIN method to authenticate.
# [Security] By default Authelia will:
# - force all SMTP connections over TLS including unauthenticated connections
# - use the disable_require_tls boolean value to disable this requirement (only works for unauthenticated connections)
2021-01-04 17:28:55 +07:00
# - validate the SMTP server x509 certificate during the TLS handshake against the hosts trusted certificates (configure in tls section)
2017-09-24 19:49:03 +07:00
smtp :
username : test
2020-04-23 08:11:32 +07:00
# Password can also be set using a secret: https://docs.authelia.com/configuration/secrets.html
2017-10-08 05:46:57 +07:00
password : password
2019-01-30 22:47:03 +07:00
host : 127.0 .0 .1
2017-09-24 19:49:03 +07:00
port : 1025
2017-10-20 03:33:10 +07:00
sender : admin@example.com
2020-11-05 06:22:10 +07:00
# HELO/EHLO Identifier. Some SMTP Servers may reject the default of localhost.
identifier : localhost
2020-04-09 07:21:28 +07:00
# Subject configuration of the emails sent.
# {title} is replaced by the text from the notifier
subject : "[Authelia] {title}"
[FEATURE] Notifier Startup Checks (#889)
* implement SMTP notifier startup check
* check dial, starttls, auth, mail from, rcpt to, reset, and quit
* log the error on failure
* implement mock
* misc optimizations, adjustments, and refactoring
* implement validate_skip config option
* fix comments to end with period
* fix suites that used smtp notifier without a smtp container
* add docs
* add file notifier startup check
* move file mode into const.go
* disable gosec linting on insecureskipverify since it's intended, warned, and discouraged
* minor PR commentary adjustment
* apply suggestions from code review
Co-Authored-By: Amir Zarrinkafsh <nightah@me.com>
2020-04-21 11:59:38 +07:00
# This address is used during the startup check to verify the email configuration is correct. It's not important what it is except if your email server only allows local delivery.
2020-04-23 08:47:27 +07:00
startup_check_address : test@authelia.com
disable_require_tls : false
2020-08-21 09:16:23 +07:00
disable_html_emails : false
2020-02-01 20:17:39 +07:00
2021-01-04 17:28:55 +07:00
tls :
# Server Name for certificate validation (in case you are using the IP or non-FQDN in the host option).
# server_name: smtp.example.com
# Skip verifying the server certificate (to allow a self-signed certificate).
skip_verify : false
# Minimum TLS version for either StartTLS or SMTPS.
minimum_version : TLS1.2
2019-04-25 04:52:08 +07:00
# Sending an email using a Gmail account is as simple as the next section.
# You need to create an app password by following: https://support.google.com/accounts/answer/185833?hl=en
## smtp:
## username: myaccount@gmail.com
2020-04-23 08:11:32 +07:00
## # Password can also be set using a secret: https://docs.authelia.com/configuration/secrets.html
2019-04-25 04:52:08 +07:00
## password: yourapppassword
## sender: admin@example.com
## host: smtp.gmail.com
## port: 587