Add example config.py for taiga back
This commit is contained in:
parent
21b7d2fcfd
commit
ad92033aff
1 changed files with 193 additions and 0 deletions
193
src/main/resources/taiga/config.py
Normal file
193
src/main/resources/taiga/config.py
Normal file
|
@ -0,0 +1,193 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
# This Source Code Form is subject to the terms of the Mozilla Public
|
||||
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||
#
|
||||
# Copyright (c) 2021-present Kaleidos Ventures SL
|
||||
|
||||
from .common import *
|
||||
import os
|
||||
|
||||
|
||||
#########################################
|
||||
## GENERIC
|
||||
#########################################
|
||||
DEBUG = False
|
||||
|
||||
DATABASES = {
|
||||
'default': {
|
||||
'ENGINE': 'django.db.backends.postgresql',
|
||||
'NAME': os.getenv('POSTGRES_DB'),
|
||||
'USER': os.getenv('POSTGRES_USER'),
|
||||
'PASSWORD': os.getenv('POSTGRES_PASSWORD'),
|
||||
'HOST': os.getenv('POSTGRES_HOST'),
|
||||
'PORT': os.getenv('POSTGRES_PORT','5432'),
|
||||
'OPTIONS': {'sslmode': os.getenv('POSTGRES_SSLMODE','disable')},
|
||||
}
|
||||
}
|
||||
SECRET_KEY = os.getenv('TAIGA_SECRET_KEY')
|
||||
|
||||
TAIGA_SITES_SCHEME = os.getenv('TAIGA_SITES_SCHEME')
|
||||
TAIGA_SITES_DOMAIN = os.getenv('TAIGA_SITES_DOMAIN')
|
||||
FORCE_SCRIPT_NAME = os.getenv('TAIGA_SUBPATH', '')
|
||||
|
||||
TAIGA_URL = f"{ TAIGA_SITES_SCHEME }://{ TAIGA_SITES_DOMAIN }{ FORCE_SCRIPT_NAME }"
|
||||
SITES = {
|
||||
"api": { "name": "api", "scheme": TAIGA_SITES_SCHEME, "domain": TAIGA_SITES_DOMAIN },
|
||||
"front": { "name": "front", "scheme": TAIGA_SITES_SCHEME, "domain": f"{ TAIGA_SITES_DOMAIN }{ FORCE_SCRIPT_NAME }" }
|
||||
}
|
||||
|
||||
INSTANCE_TYPE = "D"
|
||||
|
||||
WEBHOOKS_ENABLED = True
|
||||
|
||||
# Setting DEFAULT_PROJECT_SLUG_PREFIX to false
|
||||
# removes the username from project slug
|
||||
DEFAULT_PROJECT_SLUG_PREFIX = os.getenv('DEFAULT_PROJECT_SLUG_PREFIX', 'False') == 'True'
|
||||
|
||||
#########################################
|
||||
## MEDIA
|
||||
#########################################
|
||||
MEDIA_URL = f"{ TAIGA_URL }/media/"
|
||||
DEFAULT_FILE_STORAGE = "taiga_contrib_protected.storage.ProtectedFileSystemStorage"
|
||||
THUMBNAIL_DEFAULT_STORAGE = DEFAULT_FILE_STORAGE
|
||||
|
||||
STATIC_URL = f"{ TAIGA_URL }/static/"
|
||||
|
||||
|
||||
#########################################
|
||||
## EMAIL
|
||||
#########################################
|
||||
# https://docs.djangoproject.com/en/3.1/topics/email/
|
||||
EMAIL_BACKEND = os.getenv('EMAIL_BACKEND', 'django.core.mail.backends.console.EmailBackend')
|
||||
CHANGE_NOTIFICATIONS_MIN_INTERVAL = 120 # seconds
|
||||
|
||||
DEFAULT_FROM_EMAIL = os.getenv('DEFAULT_FROM_EMAIL', 'system@taiga.io')
|
||||
EMAIL_USE_TLS = os.getenv('EMAIL_USE_TLS', 'False') == 'True'
|
||||
EMAIL_USE_SSL = os.getenv('EMAIL_USE_SSL', 'False') == 'True'
|
||||
EMAIL_HOST = os.getenv('EMAIL_HOST', 'localhost')
|
||||
EMAIL_PORT = os.getenv('EMAIL_PORT', 587)
|
||||
EMAIL_HOST_USER = os.getenv('EMAIL_HOST_USER', 'user')
|
||||
EMAIL_HOST_PASSWORD = os.getenv('EMAIL_HOST_PASSWORD', 'password')
|
||||
|
||||
|
||||
#########################################
|
||||
## SESSION
|
||||
#########################################
|
||||
SESSION_COOKIE_SECURE = os.getenv('SESSION_COOKIE_SECURE', 'True') == 'True'
|
||||
CSRF_COOKIE_SECURE = os.getenv('CSRF_COOKIE_SECURE', 'True') == 'True'
|
||||
|
||||
|
||||
#########################################
|
||||
## EVENTS
|
||||
#########################################
|
||||
EVENTS_PUSH_BACKEND = "taiga.events.backends.rabbitmq.EventsPushBackend"
|
||||
|
||||
EVENTS_PUSH_BACKEND_URL = os.getenv('EVENTS_PUSH_BACKEND_URL')
|
||||
if not EVENTS_PUSH_BACKEND_URL:
|
||||
EVENTS_PUSH_BACKEND_URL = f"amqp://{ os.getenv('RABBITMQ_USER') }:{ os.getenv('RABBITMQ_PASS') }@taiga-events-rabbitmq:5672/taiga"
|
||||
|
||||
EVENTS_PUSH_BACKEND_OPTIONS = {
|
||||
"url": EVENTS_PUSH_BACKEND_URL
|
||||
}
|
||||
|
||||
|
||||
#########################################
|
||||
## TAIGA ASYNC
|
||||
#########################################
|
||||
CELERY_ENABLED = os.getenv('CELERY_ENABLED', 'True') == 'True'
|
||||
from kombu import Queue # noqa
|
||||
|
||||
CELERY_BROKER_URL = os.getenv('CELERY_BROKER_URL')
|
||||
if not CELERY_BROKER_URL:
|
||||
CELERY_BROKER_URL = f"amqp://{ os.getenv('RABBITMQ_USER') }:{ os.getenv('RABBITMQ_PASS') }@taiga-async-rabbitmq:5672/taiga"
|
||||
|
||||
CELERY_RESULT_BACKEND = None # for a general installation, we don't need to store the results
|
||||
CELERY_ACCEPT_CONTENT = ['pickle', ] # Values are 'pickle', 'json', 'msgpack' and 'yaml'
|
||||
CELERY_TASK_SERIALIZER = "pickle"
|
||||
CELERY_RESULT_SERIALIZER = "pickle"
|
||||
CELERY_TIMEZONE = 'Europe/Madrid'
|
||||
CELERY_TASK_DEFAULT_QUEUE = 'tasks'
|
||||
CELERY_QUEUES = (
|
||||
Queue('tasks', routing_key='task.#'),
|
||||
Queue('transient', routing_key='transient.#', delivery_mode=1)
|
||||
)
|
||||
CELERY_TASK_DEFAULT_EXCHANGE = 'tasks'
|
||||
CELERY_TASK_DEFAULT_EXCHANGE_TYPE = 'topic'
|
||||
CELERY_TASK_DEFAULT_ROUTING_KEY = 'task.default'
|
||||
|
||||
|
||||
#########################################
|
||||
## REGISTRATION
|
||||
#########################################
|
||||
PUBLIC_REGISTER_ENABLED = os.getenv('PUBLIC_REGISTER_ENABLED', 'False') == 'True'
|
||||
|
||||
|
||||
#########################################
|
||||
## CONTRIBS
|
||||
#########################################
|
||||
|
||||
# SLACK
|
||||
ENABLE_SLACK = os.getenv('ENABLE_SLACK', 'False') == 'True'
|
||||
if ENABLE_SLACK:
|
||||
INSTALLED_APPS += [
|
||||
"taiga_contrib_slack"
|
||||
]
|
||||
|
||||
# GITHUB AUTH
|
||||
# WARNING: If PUBLIC_REGISTER_ENABLED == False, currently Taiga by default prevents the OAuth
|
||||
# buttons to appear for both login and register
|
||||
ENABLE_GITHUB_AUTH = os.getenv('ENABLE_GITHUB_AUTH', 'False') == 'True'
|
||||
if PUBLIC_REGISTER_ENABLED and ENABLE_GITHUB_AUTH:
|
||||
INSTALLED_APPS += [
|
||||
"taiga_contrib_github_auth"
|
||||
]
|
||||
GITHUB_API_CLIENT_ID = os.getenv('GITHUB_API_CLIENT_ID')
|
||||
GITHUB_API_CLIENT_SECRET = os.getenv('GITHUB_API_CLIENT_SECRET')
|
||||
|
||||
# GITLAB AUTH
|
||||
# WARNING: If PUBLIC_REGISTER_ENABLED == False, currently Taiga by default prevents the OAuth
|
||||
# buttons to appear for both login and register
|
||||
ENABLE_GITLAB_AUTH = os.getenv('ENABLE_GITLAB_AUTH', 'False') == 'True'
|
||||
if PUBLIC_REGISTER_ENABLED and ENABLE_GITLAB_AUTH:
|
||||
INSTALLED_APPS += [
|
||||
"taiga_contrib_gitlab_auth"
|
||||
]
|
||||
GITLAB_API_CLIENT_ID = os.getenv('GITLAB_API_CLIENT_ID')
|
||||
GITLAB_API_CLIENT_SECRET = os.getenv('GITLAB_API_CLIENT_SECRET')
|
||||
GITLAB_URL = os.getenv('GITLAB_URL')
|
||||
|
||||
|
||||
#########################################
|
||||
## TELEMETRY
|
||||
#########################################
|
||||
ENABLE_TELEMETRY = os.getenv('ENABLE_TELEMETRY', 'True') == 'True'
|
||||
|
||||
|
||||
#########################################
|
||||
## IMPORTERS
|
||||
#########################################
|
||||
ENABLE_GITHUB_IMPORTER = os.getenv('ENABLE_GITHUB_IMPORTER', 'False') == 'True'
|
||||
if ENABLE_GITHUB_IMPORTER:
|
||||
IMPORTERS["github"] = {
|
||||
"active": True,
|
||||
"client_id": os.getenv('GITHUB_IMPORTER_CLIENT_ID'),
|
||||
"client_secret": os.getenv('GITHUB_IMPORTER_CLIENT_SECRET')
|
||||
}
|
||||
|
||||
ENABLE_JIRA_IMPORTER = os.getenv('ENABLE_JIRA_IMPORTER', 'False') == 'True'
|
||||
if ENABLE_JIRA_IMPORTER:
|
||||
IMPORTERS["jira"] = {
|
||||
"active": True,
|
||||
"consumer_key": os.getenv('JIRA_IMPORTER_CONSUMER_KEY'),
|
||||
"cert": os.getenv('JIRA_IMPORTER_CERT'),
|
||||
"pub_cert": os.getenv('JIRA_IMPORTER_PUB_CERT')
|
||||
}
|
||||
|
||||
ENABLE_TRELLO_IMPORTER = os.getenv('ENABLE_TRELLO_IMPORTER', 'False') == 'True'
|
||||
if ENABLE_TRELLO_IMPORTER:
|
||||
IMPORTERS["trello"] = {
|
||||
"active": True,
|
||||
"api_key": os.getenv('TRELLO_IMPORTER_API_KEY'),
|
||||
"secret_key": os.getenv('TRELLO_IMPORTER_SECRET_KEY')
|
||||
}
|
Loading…
Reference in a new issue