Configuration¶
You can configure pretalx using config files or environment variables. You can combine those two options, and their precedence is in this order:
Environment variables
Configuration files
The config file in the environment variable
PRETALX_CONFIG_FILE
if present, orThe following three configuration files in this order:
The config file
pretalx.cfg
in thesrc
directory, next to thepretalx.example.cfg
file.The config file
~/.pretalx.cfg
in the home of the executing user.The config file
/etc/pretalx/pretalx.cfg
Sensible defaults
This page explains the options grouped by configuration file sections. You’ll find the environment variable next to their corresponding settings. A config file looks like this:
# This is an example pretalx configuration file.
# Documentation: https://docs.pretalx.org/administrator/configure.html
[filesystem]
data = /var/pretalx/data
static = /var/pretalx/static
[site]
debug = False
url = https://pretalx.mydomain.com
[database]
# For MySQL, replace with "mysql"
backend = postgresql
name = pretalx
user = pretalx
# For MySQL, enter the user password. For PostgreSQL on the same host,
# we don't need one because we can use peer authentification if our
# PostgreSQL user matches our unix user.
password = Change this in production or you're going to have a bad time
# For MySQL, you can use a local socket, e.g. /var/run/mysqld/mysqld.sock
# For a remote host, supply an IP address
# For local postgres authentication, you can leave the host empty
host = localhost
port = 5432
[mail]
from = admin@localhost
host = localhost
port = 25
user = admin
password = Change this in production or you're going to have a bad time
tls = False
ssl = True
The configuration format is the INI file format as understood by Python.
It’s worth mentioning that you can use any of yes
/no
, on
/off
,
true
/false
and 1
/0
to set boolean settings. You can add add
comments by starting a line with ;
or #
. Also strings don’t need to be
quoted as every value is already a string.
The filesystem section¶
data
¶
The
data
option describes the path that is the base for all other directories. pretalx will also save its log files there. Unless you have a compelling reason to keep other files apart, setting thedata
option is the easiest way to configure file storage.Environment variable:
PRETALX_DATA_DIR
Default: A directory called
data
next to pretalx’smanage.py
.
media
¶
The
media
option sets the media directory that contains user generated files. It needs to be writable by the pretalx process.Environment variable:
PRETALX_FILESYSTEM_MEDIA
Default: A directory called
media
in thedata
directory (see above).
logs
¶
The
logs
option sets the log directory that contains logged data. It needs to be writable by the pretalx process.Environment variable:
PRETALX_FILESYSTEM_LOGS
Default: A directory called
logs
in thedata
directory (see above).
static
¶
The
statics
option sets the directory that contains static files. It needs to be writable by the pretalx process. pretalx will put files there during therebuild
andcollectstatic
commands.Environment variable:
PRETALX_FILESYSTEM_STATIC
Default: A directory called
static.dist
next to pretalx’smanage.py
.
The site section¶
debug
¶
Decides if pretalx runs in debug mode. Please use this mode for development and debugging, not for live usage.
Environment variable:
PRETALX_DEBUG
Default:
True
if you’re executingrunserver
,False
otherwise. Never run a production server in debug mode.
url
¶
pretalx uses this value when it has to render full URLs, for example in emails or feeds. It is also used to determined the allowed incoming hosts.
Environment variable:
PRETALX_SITE_URL
Default:
http://localhost
secret
¶
Every Django application has a secret that Django uses for cryptographic signing. You do not need to set this variable – pretalx will generate a secret key and save it in a local file if you do not set it.
Default: None
media
¶
The URL under which the media files (all files uploaded by users or generated by pretalx) should be. If you change this value, remember to change your web server configuration, too!
Environment variable:
PRETALX_SITE_MEDIA
Default:
/media/
static
¶
The URL under which the static files should be. This includes all JavaScript and CSS files that are packaged with pretalx. If you change this value, remember to change your web server configuration, too!
Environment variable:
PRETALX_SITE_STATIC
Default:
/static/
csp
, csp_script
, csp_style
, csp_img
, csp_form
¶
Use any of these settings to update the matching CSP security headers. Your configuration values will be added to the default headers, they won’t replace them completely! If you need to include special values like
self
, remember to use single tick quotation marks:csp=https://rixx.de,'self'
Environment variables:
PRETALX_SITE_CSP
,PRETALX_SITE_CSP_SCRIPT
etc.Default:
''
The database section¶
backend
¶
pretalx supports most SQL databases. You’ll need to install the appropriate Python library for each of them, as described in the table below.
Environment variable:
PRETALX_DB_TYPE
Default:
sqlite3
Database |
Configuration string |
pip package |
---|---|---|
PostgresQL |
|
|
MySQL |
|
|
SQLite |
|
|
name
¶
The database’s name.
Environment variable:
PRETALX_DB_NAME
Default:
''
user
¶
The database user, if applicable.
Environment variable:
PRETALX_DB_USER
Default:
''
password
¶
The database password, if applicable.
Environment variable:
PRETALX_DB_PASS
Default:
''
host
¶
The database host, or the socket location, as needed. You can set this variable to a socket path for MySQL. For local PostgreSQL authentication, you can leave this variable empty.
Environment variable:
PRETALX_DB_HOST
Default:
''
port
¶
The database port, if applicable.
Environment variable:
PRETALX_DB_PORT
Default:
''
The mail section¶
This section serves to configure the email server pretalx will use to send emails by default. Events can override these settings in the web interface. However, even with event-specific settings, pretalx will use these global settings for non-event-specific emails like password resets (even when triggered from an event context) and team invitations.
from
¶
The fall-back sender address, e.g. for when pretalx sends event independent emails.
Environment variable:
PRETALX_MAIL_FROM
Default:
admin@localhost
host
¶
The email server host address.
Environment variable:
PRETALX_MAIL_HOST
Default:
localhost
port
¶
The email server port.
Environment variable:
PRETALX_MAIL_PORT
Default:
25
user
¶
The user account for mail server authentication, if needed.
Environment variable:
PRETALX_MAIL_USER
Default:
''
password
¶
The password for mail server authentication, if needed.
Environment variable:
PRETALX_MAIL_PASSWORD
Default:
''
tls
¶
Should pretalx use TLS when sending mail? Please choose either TLS or SSL.
Environment variable:
PRETALX_MAIL_TLS
Default:
False
ssl
¶
Should pretalx use SSL when sending mail? Please choose either TLS or SSL.
Environment variable:
PRETALX_MAIL_SSL
Default:
False
The celery section¶
Celery is not a requirement for pretalx. Celery runs as a separate process, and allows you to execute long-running tasks away from the usual request-response cycle.
Warning
If this config section is present, pretalx will assume that Celery workers exist and collect talks. If you include this section without providing Celery workers, no asynchronous tasks (like email sending) will be processed. If you do not use Celery, omit this section in your configuration.
backend
¶
The celery backend. If you use a standard redis-based setup,
redis://127.0.0.1/1
would be a sensible value.Environment variable:
PRETALX_CELERY_BACKEND
Default:
''
broker
¶
The celery broker. If you use a standard redis-based setup,
redis://127.0.0.1/2
would be a sensible value.Environment variable:
PRETALX_CELERY_BROKER
Default:
''
The redis section¶
If you configure a redis server, pretalx can use it for locking, caching and
session storage to speed up operations. You will need to install django_redis
.
location
¶
The location of redis, if you want to use it as a cache.
redis://[:password]@127.0.0.1:6379/1
would be a sensible value, orunix://[:password]@/path/to/socket.sock?db=0
if you prefer to use sockets.Environment variable:
PRETALX_REDIS
Default:
''
session
¶
If you want to use redis as your session storage, set this to
True
.Environment variable:
PRETALX_REDIS_SESSIONS
Default:
False
The logging section¶
email
¶
The email address (or addresses, comma separated) to send system logs to.
Environment variable:
PRETALX_LOGGING_EMAIL
Default:
''
email_level
¶
The log level to start sending emails at. Any of
[DEBUG, INFO, WARNING, ERROR, CRITICAL]
.Environment variable:
PRETALX_LOGGING_EMAIL_LEVEL
Default:
ERROR
The locale section¶
language_code
¶
The system’s default locale.
Environment variable:
PRETALX_LANGUAGE_CODE
Default:
en
time_zone
¶
The system’s default time zone as a
pytz
name.Environment variable:
PRETALX_TIME_ZONE
Default:
UTC