mirror of
https://github.com/ChristianLight/tutor.git
synced 2024-05-30 21:00:49 +00:00
728ef966dc
- 💥[Improvement] Upgrade Open edX to Koa - 💥 Setting changes: - The ``ACTIVATE_HTTPS`` setting was renamed to ``ENABLE_HTTPS``. - Other ``ACTIVATE_*`` variables were all renamed to ``RUN_*``. - The ``WEB_PROXY`` setting was removed and ``RUN_CADDY`` was added. - The ``NGINX_HTTPS_PORT`` setting is deprecated. - Architectural changes: - Use Caddy as a web proxy for automated SSL/TLS certificate generation: - Nginx no longer listens to port 443 for https traffic - The Caddy configuration file comes with a new ``caddyfile`` patch for much simpler SSL/TLS management. - Configuration files for web proxies are no longer provided. - Kubernetes deployment no longer requires setting up a custom Ingress resource or custom manager. - Gunicorn and Whitenoise are replaced by uwsgi: this increases boostrap performance and makes it no longer necessary to mount media folders in the Nginx container. - Replace memcached and rabbitmq by redis. - Additional features: - Make it possible to disable all plugins at once with ``plugins disable all``. - Add ``tutor k8s wait`` command to wait for a pod to become ready - Faster, more reliable static assets with local memory caching - Deprecation: proxy files for Apache and Nginx are no longer provided out of the box. - Removed plugin `{{ patch (...) }}` statements: - "https-create", "k8s-ingress-rules", "k8s-ingress-tls-hosts": these are no longer necessary. Instead, declare your app in the "caddyfile" patch. - "local-docker-compose-nginx-volumes": this patch was primarily used to serve media assets. The recommended is now to serve assets with uwsgi.
141 lines
5.1 KiB
Python
141 lines
5.1 KiB
Python
####### Settings common to LMS and CMS
|
|
import json
|
|
import os
|
|
|
|
from xmodule.modulestore.modulestore_settings import update_module_store_settings
|
|
|
|
# Mongodb connection parameters: simply modify `mongodb_parameters` to affect all connections to MongoDb.
|
|
mongodb_parameters = {
|
|
"host": "{{ MONGODB_HOST }}",
|
|
"port": {{ MONGODB_PORT }},
|
|
{% if MONGODB_USERNAME and MONGODB_PASSWORD %}
|
|
"user": "{{ MONGODB_USERNAME }}",
|
|
"password": "{{ MONGODB_PASSWORD }}",
|
|
{% else %}
|
|
"user": None,
|
|
"password": None,
|
|
{% endif %}
|
|
"db": "{{ MONGODB_DATABASE }}",
|
|
}
|
|
DOC_STORE_CONFIG = mongodb_parameters
|
|
CONTENTSTORE = {
|
|
"ENGINE": "xmodule.contentstore.mongo.MongoContentStore",
|
|
"ADDITIONAL_OPTIONS": {},
|
|
"DOC_STORE_CONFIG": DOC_STORE_CONFIG
|
|
}
|
|
# Load module store settings from config files
|
|
update_module_store_settings(MODULESTORE, doc_store_settings=DOC_STORE_CONFIG)
|
|
DATA_DIR = "/openedx/data/"
|
|
for store in MODULESTORE["default"]["OPTIONS"]["stores"]:
|
|
store["OPTIONS"]["fs_root"] = DATA_DIR
|
|
|
|
# Behave like memcache when it comes to connection errors
|
|
DJANGO_REDIS_IGNORE_EXCEPTIONS = True
|
|
|
|
DEFAULT_FROM_EMAIL = ENV_TOKENS.get("DEFAULT_FROM_EMAIL", ENV_TOKENS["CONTACT_EMAIL"])
|
|
DEFAULT_FEEDBACK_EMAIL = ENV_TOKENS.get("DEFAULT_FEEDBACK_EMAIL", ENV_TOKENS["CONTACT_EMAIL"])
|
|
SERVER_EMAIL = ENV_TOKENS.get("SERVER_EMAIL", ENV_TOKENS["CONTACT_EMAIL"])
|
|
TECH_SUPPORT_EMAIL = ENV_TOKENS.get("TECH_SUPPORT_EMAIL", ENV_TOKENS["CONTACT_EMAIL"])
|
|
CONTACT_EMAIL = ENV_TOKENS.get("CONTACT_EMAIL", ENV_TOKENS["CONTACT_EMAIL"])
|
|
BUGS_EMAIL = ENV_TOKENS.get("BUGS_EMAIL", ENV_TOKENS["CONTACT_EMAIL"])
|
|
UNIVERSITY_EMAIL = ENV_TOKENS.get("UNIVERSITY_EMAIL", ENV_TOKENS["CONTACT_EMAIL"])
|
|
PRESS_EMAIL = ENV_TOKENS.get("PRESS_EMAIL", ENV_TOKENS["CONTACT_EMAIL"])
|
|
PAYMENT_SUPPORT_EMAIL = ENV_TOKENS.get("PAYMENT_SUPPORT_EMAIL", ENV_TOKENS["CONTACT_EMAIL"])
|
|
BULK_EMAIL_DEFAULT_FROM_EMAIL = ENV_TOKENS.get("BULK_EMAIL_DEFAULT_FROM_EMAIL", ENV_TOKENS["CONTACT_EMAIL"])
|
|
API_ACCESS_MANAGER_EMAIL = ENV_TOKENS.get("API_ACCESS_MANAGER_EMAIL", ENV_TOKENS["CONTACT_EMAIL"])
|
|
API_ACCESS_FROM_EMAIL = ENV_TOKENS.get("API_ACCESS_FROM_EMAIL", ENV_TOKENS["CONTACT_EMAIL"])
|
|
|
|
# Get rid completely of coursewarehistoryextended, as we do not use the CSMH database
|
|
INSTALLED_APPS.remove("lms.djangoapps.coursewarehistoryextended")
|
|
DATABASE_ROUTERS.remove(
|
|
"openedx.core.lib.django_courseware_routers.StudentModuleHistoryExtendedRouter"
|
|
)
|
|
|
|
# Set uploaded media file path
|
|
MEDIA_ROOT = "/openedx/media/"
|
|
|
|
# Add your MFE and third-party app domains here
|
|
CORS_ORIGIN_WHITELIST = []
|
|
|
|
# Video settings
|
|
VIDEO_IMAGE_SETTINGS["STORAGE_KWARGS"]["location"] = MEDIA_ROOT
|
|
VIDEO_TRANSCRIPTS_SETTINGS["STORAGE_KWARGS"]["location"] = MEDIA_ROOT
|
|
|
|
GRADES_DOWNLOAD = {
|
|
"STORAGE_TYPE": "",
|
|
"STORAGE_KWARGS": {
|
|
"base_url": "/media/grades/",
|
|
"location": "/openedx/media/grades",
|
|
},
|
|
}
|
|
|
|
ORA2_FILEUPLOAD_BACKEND = "filesystem"
|
|
ORA2_FILEUPLOAD_ROOT = "/openedx/data/ora2"
|
|
ORA2_FILEUPLOAD_CACHE_NAME = "ora2-storage"
|
|
|
|
# Change syslog-based loggers which don't work inside docker containers
|
|
LOGGING["handlers"]["local"] = {
|
|
"class": "logging.handlers.WatchedFileHandler",
|
|
"filename": os.path.join(LOG_DIR, "all.log"),
|
|
"formatter": "standard",
|
|
}
|
|
LOGGING["handlers"]["tracking"] = {
|
|
"level": "DEBUG",
|
|
"class": "logging.handlers.WatchedFileHandler",
|
|
"filename": os.path.join(LOG_DIR, "tracking.log"),
|
|
"formatter": "standard",
|
|
}
|
|
LOGGING["loggers"]["tracking"]["handlers"] = ["console", "local", "tracking"]
|
|
|
|
# Email
|
|
EMAIL_USE_SSL = {{ SMTP_USE_SSL }}
|
|
# Forward all emails from edX's Automated Communication Engine (ACE) to django.
|
|
ACE_ENABLED_CHANNELS = ["django_email"]
|
|
ACE_CHANNEL_DEFAULT_EMAIL = "django_email"
|
|
ACE_CHANNEL_TRANSACTIONAL_EMAIL = "django_email"
|
|
EMAIL_FILE_PATH = "/tmp/openedx/emails"
|
|
|
|
LOCALE_PATHS.append("/openedx/locale/contrib/locale")
|
|
LOCALE_PATHS.append("/openedx/locale/user/locale")
|
|
|
|
# Allow the platform to include itself in an iframe
|
|
X_FRAME_OPTIONS = "SAMEORIGIN"
|
|
|
|
{% set jwt_rsa_key = rsa_import_key(JWT_RSA_PRIVATE_KEY) %}
|
|
JWT_AUTH["JWT_ISSUER"] = "{{ JWT_COMMON_ISSUER }}"
|
|
JWT_AUTH["JWT_AUDIENCE"] = "{{ JWT_COMMON_AUDIENCE }}"
|
|
JWT_AUTH["JWT_SECRET_KEY"] = "{{ JWT_COMMON_SECRET_KEY }}"
|
|
JWT_AUTH["JWT_PRIVATE_SIGNING_JWK"] = json.dumps(
|
|
{
|
|
"kid": "openedx",
|
|
"kty": "RSA",
|
|
"e": "{{ jwt_rsa_key.e|long_to_base64 }}",
|
|
"d": "{{ jwt_rsa_key.d|long_to_base64 }}",
|
|
"n": "{{ jwt_rsa_key.n|long_to_base64 }}",
|
|
"p": "{{ jwt_rsa_key.p|long_to_base64 }}",
|
|
"q": "{{ jwt_rsa_key.q|long_to_base64 }}",
|
|
}
|
|
)
|
|
JWT_AUTH["JWT_PUBLIC_SIGNING_JWK_SET"] = json.dumps(
|
|
{
|
|
"keys": [
|
|
{
|
|
"kid": "openedx",
|
|
"kty": "RSA",
|
|
"e": "{{ jwt_rsa_key.e|long_to_base64 }}",
|
|
"n": "{{ jwt_rsa_key.n|long_to_base64 }}",
|
|
}
|
|
]
|
|
}
|
|
)
|
|
JWT_AUTH["JWT_ISSUERS"] = [
|
|
{
|
|
"ISSUER": "{{ JWT_COMMON_ISSUER }}",
|
|
"AUDIENCE": "{{ JWT_COMMON_AUDIENCE }}",
|
|
"SECRET_KEY": "{{ OPENEDX_SECRET_KEY }}"
|
|
}
|
|
]
|
|
|
|
{{ patch("openedx-common-settings") }}
|
|
######## End of settings common to LMS and CMS
|