2025.09.14-18:02:28
This commit is contained in:
0
django_project/local/__init__.py
Normal file
0
django_project/local/__init__.py
Normal 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"
|
||||
|
||||
|
||||
|
||||
@@ -18,6 +18,8 @@ from django.contrib import admin
|
||||
from django.urls import path,include
|
||||
from django.conf import settings
|
||||
urlpatterns = [
|
||||
path('',include("tinywiki.urls")),
|
||||
path("user/",include("user.urls")),
|
||||
path('admin/', admin.site.urls),
|
||||
]
|
||||
|
||||
@@ -28,5 +30,5 @@ if settings.DEBUG:
|
||||
*debug_toolbar_urls(),
|
||||
*static(settings.STATIC_URL, document_root=settings.STATIC_ROOT),
|
||||
*static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT),
|
||||
path('__reload__/',include("django_browser_relaod.urls"))
|
||||
path('__reload__/',include("django_browser_reload.urls"))
|
||||
]
|
||||
Reference in New Issue
Block a user