2025.09.14-18:02:28

This commit is contained in:
2025-09-14 18:02:28 +02:00
parent 565ef0cad1
commit ff37c9cd8b
32 changed files with 733 additions and 22 deletions

View File

@@ -11,6 +11,8 @@ https://docs.djangoproject.com/en/5.2/ref/settings/
"""
from pathlib import Path
import sys
from environ import Env
# Build paths inside the project like this: BASE_DIR / 'subdir'.
BASE_DIR = Path(__file__).resolve().parent.parent
@@ -20,12 +22,24 @@ ENV = Env(
ALLOWED_HOSTS=(list,['*']),
STATIC_URL=(str,"static/"),
STATIC_ROOT=(Path,BASE_DIR/".static"),
MEDIA_URL=("media/")
MEDIA_URL=(str,"media/"),
MEDIA_ROOT=(Path,BASE_DIR/".media"),
SECRET_KEY=(str,'django-insecure-tqis9c9@z_=cq36ic4h-l7h!ln8*@_*+e96z0m^-^mx_avdcw*')
SECRET_KEY=(str,'django-insecure-tqis9c9@z_=cq36ic4h-l7h!ln8*@_*+e96z0m^-^mx_avdcw*'),
EMAIL_BACKEND=(str,"console"),
)
DEBUG = True
DEBUG = ENV.bool("DEBUG")
DEBUG = ENV.bool("DEBUG")
if DEBUG:
_env_file = Path(ENV.path("DOTENV",str(BASE_DIR/'.env.dev'))).resolve()
if _env_file.is_file():
ENV.read_env(_env_file)
else:
_env_file = Path(ENV.path("DOTENV",str(BASE_DIR/'.env.prod'))).resolve()
if _env_file.is_file():
ENV.read_env(_env_file)
del _env_file
# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/5.2/howto/deployment/checklist/
@@ -40,8 +54,7 @@ ALLOWED_HOSTS = ENV.list("ALLOWED_HOSTS")
# Application definition
INSTALLED_APPS = [
django_apps= [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
@@ -50,6 +63,23 @@ INSTALLED_APPS = [
'django.contrib.staticfiles',
]
third_party_apps = [
'allauth',
'allauth.account',
'allauth.socialaccount',
'allauth.socialaccount.providers.oauth2', # required for github
'allauth.socialaccount.providers.github',
'allauth.socialaccount.providers.google',
'allauth.socialaccount.providers.openid',
'allauth.socialaccount.providers.steam',
'widget_tweaks',
]
project_apps = [
'user',
'tinywiki',
]
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
@@ -58,6 +88,30 @@ MIDDLEWARE = [
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
'django.middleware.locale.LocaleMiddleware',
'allauth.account.middleware.AccountMiddleware',
]
if DEBUG:
third_party_apps += [
"django_browser_reload",
"debug_toolbar",
]
MIDDLEWARE = [
"debug_toolbar.middleware.DebugToolbarMiddleware",
*MIDDLEWARE,
'django_browser_reload.middleware.BrowserReloadMiddleware',
]
import socket
hostname, _x, ips = socket.gethostbyname_ex(socket.gethostname())
podman_ips = [ip for ip in ips]
docker_ips = [ip[:-1] + "1" for ip in ips]
INTERNAL_IPS = podman_ips + docker_ips + ["127.0.0.1", "localhost"] + ["192.168.65.1"]
INSTALLED_APPS = [
*django_apps,
*third_party_apps,
*project_apps,
]
ROOT_URLCONF = 'django_project.urls'
@@ -91,6 +145,8 @@ DATABASES = {
# Password validation
# https://docs.djangoproject.com/en/5.2/ref/settings/#auth-password-validators
AUTH_USER_MODEL = "user.UserProfile"
AUTH_PASSWORD_VALIDATORS = [
{
'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
@@ -130,3 +186,19 @@ MEDIA_ROOT = ENV("MEDIA_ROOT")
# https://docs.djangoproject.com/en/5.2/ref/settings/#default-auto-field
DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
if ENV("EMAIL_BACKEND") == 'smtp':
EMAIL_BACKEND = "django.core.mail.backends.smtp.EmailBackend"
EMAIL_HOST = ENV("EMAIL_HOST","localhost")
EMAIL_PORT = ENV.int("EMAIL_PORT",25)
EMAIL_HOST_USER = ENV("EMAIL_HOST_USER","")
EMAIL_HOST_PASSWORD = ENV("EMAIL_HOST_PASSWORD","")
EMAIL_SSL_KEYFILE = ENV("EMAIL_SSL_KEYFILE",None)
EMAIL_SSL_CERTFILE = ENV("EMAIL_SSL_CERTFILE",None)
EMAIL_TIMEOUT = ENV("EMAIL_TIMEOUT", 60)
else:
if ENV("EMAIL_BACKEND") != 'console':
print("Email backend not known falling back to console!",file=sys.stderr)
EMAIL_BACKEND = "django.core.mail.backends.console.EmailBackend"