mirror of
https://github.com/ChristianLight/tutor.git
synced 2025-01-23 13:38:24 +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.
71 lines
2.0 KiB
Python
71 lines
2.0 KiB
Python
# -*- mode: python -*-
|
|
import importlib
|
|
import os
|
|
import pkg_resources
|
|
import wcwidth
|
|
|
|
block_cipher = None
|
|
|
|
datas = [("./tutor/templates", "./tutor/templates")]
|
|
hidden_imports = []
|
|
|
|
# Fix missing wcwidth/version.json file
|
|
datas.append((os.path.dirname(wcwidth.__file__), 'wcwidth'))
|
|
|
|
# Auto-discover plugins and include patches & templates folders
|
|
for entrypoint in pkg_resources.iter_entry_points("tutor.plugin.v0"):
|
|
plugin_name = entrypoint.name
|
|
plugin = entrypoint.load()
|
|
plugin_root = os.path.dirname(plugin.__file__)
|
|
plugin_root_module_name = os.path.basename(plugin_root)
|
|
hidden_imports.append(entrypoint.module_name)
|
|
for folder in ["patches", "templates"]:
|
|
path = os.path.join(plugin_root, folder)
|
|
if os.path.exists(path):
|
|
datas.append((path, os.path.join(plugin_root_module_name, folder)))
|
|
# Fix license import: if we don't declare some modules, pyinstaller does not find them
|
|
hidden_imports.append("tutorlts.__about__")
|
|
hidden_imports.append("Crypto.Cipher.AES")
|
|
hidden_imports.append("Crypto.Cipher.PKCS1_OAEP")
|
|
hidden_imports.append("Crypto.Hash.SHA256")
|
|
hidden_imports.append("Crypto.PublicKey.RSA")
|
|
hidden_imports.append("Crypto.Random")
|
|
hidden_imports.append("Crypto.Signature.PKCS1_v1_5")
|
|
hidden_imports.append("kubernetes")
|
|
hidden_imports.append("uuid")
|
|
|
|
|
|
# The following was initially generated with:
|
|
# pyinstaller --onefile --name=tutor --add-data=./tutor/templates:./tutor/templates ./bin/main.py
|
|
|
|
a = Analysis(
|
|
["bin/main.py"],
|
|
pathex=[os.path.abspath(".")],
|
|
binaries=[],
|
|
datas=datas,
|
|
hiddenimports=hidden_imports,
|
|
hookspath=[],
|
|
runtime_hooks=[],
|
|
excludes=[],
|
|
win_no_prefer_redirects=False,
|
|
win_private_assemblies=False,
|
|
cipher=block_cipher,
|
|
noarchive=False,
|
|
)
|
|
pyz = PYZ(a.pure, a.zipped_data, cipher=block_cipher)
|
|
exe = EXE(
|
|
pyz,
|
|
a.scripts,
|
|
a.binaries,
|
|
a.zipfiles,
|
|
a.datas,
|
|
[],
|
|
name="tutor",
|
|
debug=False,
|
|
bootloader_ignore_signals=False,
|
|
strip=False,
|
|
upx=True,
|
|
runtime_tmpdir=None,
|
|
console=True,
|
|
)
|