Application Settings¶
Keystone-API reads application settings from environment variables. Individual settings are listed below by category and use case.
Security Settings¶
Security settings are used to configure application networking and request signing. These values should be chosen with care. Improperly configured settings can introduce dangerous vulnerabilities and may damage your production deployment.
Core Security¶
Keystone-API requires a random secret key to sign and verify requests.
Secret keys are conventionally 50 characters long and can be generated using common unities like openssl
.
For example: openssl rand -base64 48 | cut -c1-50
Setting Name | Default Value | Description |
---|---|---|
SECURE_SECRET_KEY |
Randomly generated | Key value used to enforce cryptographic signing. |
SSL/TLS¶
Enabling TLS is strongly recommended in production. Enabling HSTS is also recommended, but only when TLS is already fully configured. Administrators are cautioned to consider the potentially irreversible side effects of HSTS before enabling it.
Setting Name | Default Value | Description |
---|---|---|
SECURE_SSL_REDIRECT |
False |
Automatically redirect all HTTP traffic to HTTPS. |
SECURE_HSTS_SECONDS |
0 (Disabled) |
HSTS cache duration in seconds. |
SECURE_HSTS_SUBDOMAINS |
False |
Enable HSTS for subdomains. |
SECURE_HSTS_PRELOAD |
False |
Enable HSTS preload functionality. |
CORS/CSRF¶
CORS and CSRF settings define which domains are allowed to interact with the Keystone-API.
Setting Name | Default Value |
Description |
---|---|---|
SECURE_ALLOWED_HOSTS |
localhost,127.0.0.1 |
Comma-separated list of accepted host/domain names (without protocol). |
SECURE_ALLOWED_ORIGINS |
See default local addresses. | Comma-separated list of accepted CORS origin domains (with protocol). |
SECURE_CSRF_ORIGINS |
See default local addresses. | Comma-separated list of accepted CSRF origin domains (with protocol). |
SECURE_SSL_TOKENS |
False |
Only issue session/CSRF tokens over secure connections. |
SECURE_SESSION_AGE |
1209600 (2 weeks) |
Number of seconds before session tokens expire. |
Default values are defined relative to the following list of default local addresses:
http://localhost:80
https://localhost:443
http://localhost:4200
http://localhost:8000
http://127.0.0.1:80
https://127.0.0.1:443
http://127.0.0.1:4200
http://127.0.0.1:8000
General Configuration¶
Keystone uses various static files and user content to facilitate operation.
By default, these files are stored in subdirectories of the installed application directory (<app>
).
Setting Name | Default Value | Description |
---|---|---|
CONFIG_TIMEZONE |
UTC |
The timezone to use when rendering date/time values. |
CONFIG_STATIC_DIR |
<app>/static_files |
Where to store internal static files required by the application. |
CONFIG_UPLOAD_DIR |
<app>/media |
Where to store file data uploaded by users. |
CONFIG_UPLOAD_SIZE |
2621440 (2.5 MB) |
Maximum allowed file upload size in bytes. |
CONFIG_METRICS_PORTS |
9101 through 9150 |
Port numbers used to expose prometheus metrics (e.g., 9101,9102,9103 ). |
Logging¶
In addition to writing application logs to disk, Keystone stores audit logs and request history in the application database. All log values are automatically rotated and purged by the application.
Setting Name | Default Value | Description |
---|---|---|
LOG_APP_LEVEL |
WARNING |
Only record application logs above this level (accepts CRITICAL , ERROR , WARNING , INFO , or DEBUG ). |
LOG_APP_FILE |
<app>/keystone.log |
Destination file path for application logs. |
LOG_APP_RETENTION_BYTES |
10485760 (10 MB) |
Maximum log file size before rotating log files. |
LOG_APP_RETENTION_FILES |
5 |
Maximum rotated log files to keep. |
LOG_REQ_RETENTION_SEC |
2592000 (30 days) |
How long to store request logs in seconds. Set to 0 to keep all records. |
LOG_AUD_RETENTION_SEC |
2592000 (30 days) |
How long to store audit logs in seconds. Set to 0 to keep all records. |
API Throttling¶
API settings are used to throttle incoming API requests against a maximum limit.
Limits are specified as the maximum number of requests per day
, minute
, hour
, or second
.
Setting Name | Default Value | Description |
---|---|---|
API_THROTTLE_ANON |
120/min |
Rate limiting for anonymous (unauthenticated) users. |
API_THROTTLE_USER |
300/min |
Rate limiting for authenticated users. |
Database Connection¶
Official support is included for both SQLite and PostgreSQL database backends. Using SQLite is intended for development and demonstrative use cases only. The PostgreSQL backend should always be used in production settings.
Setting Name | Default Value | Description |
---|---|---|
DB_POSTGRES_ENABLE |
False |
Use PostgreSQL instead of the default Sqlite driver. |
DB_NAME |
keystone |
The name of the application database. |
DB_USER |
Username for database authentication (PostgreSQL only). | |
DB_PASSWORD |
Password for database authentication (PostgreSQL only). | |
DB_HOST |
localhost |
Database host address (PostgreSQL only). |
DB_PORT |
5432 |
Database host port (PostgreSQL only). |
Redis Connection¶
Redis settings define the network location and connection information for the application Redis cache. Enabling password authentication is recommended.
Setting Name | Default Value | Description |
---|---|---|
REDIS_HOST |
127.0.0.1 |
URL for the Redis message cache. |
REDIS_PORT |
6379 |
Port number for the Redis message cache. |
REDIS_DB |
0 |
The Redis database number to use. |
REDIS_PASSWORD |
Optionally connect using the given password. |
Email Notifications¶
Keystone will default to using the local server when issuing email notifications. Securing your production email server with a username/password is recommended, but not required.
Setting Name | Default Value | Description |
---|---|---|
EMAIL_HOST |
localhost |
The host server to use for sending email. |
EMAIL_HOST_USER |
Username to use for the SMTP server. | |
EMAIL_HOST_PASSWORD |
Password to use for the SMTP server. | |
EMAIL_PORT |
25 |
Port to use for the SMTP server. |
EMAIL_USE_TLS |
False |
Use a TLS connection to the SMTP server. |
EMAIL_FROM_ADDRESS |
noreply@keystone.bot |
The default "from" address used in email notifications. |
EMAIL_TEMPLATE_DIR |
/etc/keystone/templates |
Directory to search for customized email templates. |
LDAP Authentication¶
Enabling LDAP authentication is optional and disabled by default.
To enable LDAP, set the AUTH_LDAP_SERVER_URI
value to the desired LDAP endpoint.
Application user fields are mapped to LDAP attributes by specifying the AUTH_LDAP_ATTR_MAP
setting.
The following example maps the first_name
and last_name
fields used by Keystone to the LDAP attributes givenName
and sn
:
AUTH_LDAP_ATTR_MAP="first_name=givenName,last_name=sn"
See the apps.users.models.User
class for a full list of available Keystone fields.
Setting Name | Default Value | Description |
---|---|---|
AUTH_LDAP_SERVER_URI |
The URI of the LDAP server. | |
AUTH_LDAP_START_TLS |
True |
Whether to use TLS when connecting to the LDAP server. |
AUTH_LDAP_BIND_DN |
Optionally bind LDAP queries to the given DN. | |
AUTH_LDAP_BIND_PASSWORD |
The password to use when binding to the LDAP server. | |
AUTH_LDAP_USER_SEARCH |
(uid=%(user)s) |
The search query for finding a user in the LDAP server. |
AUTH_LDAP_REQUIRE_CERT |
False |
Whether to require certificate verification. |
AUTH_LDAP_ATTR_MAP |
A mapping of user fields to LDAP attribute names. | |
AUTH_LDAP_PURGE_REMOVED |
False |
Delete users when removed from LDAP instead of deactivating them. |
Developer Settings¶
The following settings are intended for use in debugging or development.
Setting Name | Default Value | Description |
---|---|---|
DEBUG_EMAIL_DIR |
Write emails to disk instead of using the SMTP server. |