import os from pathlib import Path import environ env = environ.Env() # Build paths inside the project like this: BASE_DIR / 'subdir'. BASE_DIR = Path(__file__).resolve().parent.parent # Quick-start development settings - unsuitable for production # See https://docs.djangoproject.com/en/4.2/howto/deployment/checklist/ # SECURITY WARNING: keep the secret key used in production secret! SECRET_KEY = ")g-j2v+*dvjtnz)q-3+*y7*lq$el$im8p^wr@2v$g^u99quq50" # SECURITY WARNING: don't run with debug turned on in production! # DEBUG = True DEBUG = env("DEBUG") CSRF_TRUSTED_ORIGINS = ["https://*.nabu-jena.de", "https://*.127.0.0.1"] # ALLOWED_HOSTS = [] ALLOWED_HOSTS = env("DJANGO_ALLOWED_HOSTS", default=[]) # Application definition INSTALLED_APPS = [ # ----------------------------------- # Jazzmin # ----------------------------------- "jazzmin", "django.contrib.admin", "django.contrib.auth", "django.contrib.contenttypes", "django.contrib.sessions", "django.contrib.messages", "django.contrib.staticfiles", # ----------------------------------- # All auth # ----------------------------------- "allauth", "allauth.account", "allauth.socialaccount", # ----------------------------------- # Crispy forms, modals and bootstrap5 # ----------------------------------- "bootstrap_modal_forms", "crispy_bootstrap5", "crispy_forms", # ----------------------------------- # My Apps # ----------------------------------- "aviary", "bird", "costs", "rescuer", "sites", ] MIDDLEWARE = [ "django.middleware.security.SecurityMiddleware", "whitenoise.middleware.WhiteNoiseMiddleware", "django.contrib.sessions.middleware.SessionMiddleware", "django.middleware.common.CommonMiddleware", "django.middleware.csrf.CsrfViewMiddleware", "django.contrib.auth.middleware.AuthenticationMiddleware", "django.contrib.messages.middleware.MessageMiddleware", "django.middleware.clickjacking.XFrameOptionsMiddleware", ] ROOT_URLCONF = "core.urls" TEMPLATES = [ { "BACKEND": "django.template.backends.django.DjangoTemplates", "DIRS": [os.path.join(BASE_DIR, "templates")], "APP_DIRS": True, "OPTIONS": { "context_processors": [ "django.template.context_processors.debug", "django.template.context_processors.request", "django.contrib.auth.context_processors.auth", "django.contrib.messages.context_processors.messages", ], }, }, ] AUTHENTICATION_BACKENDS = [ # Needed to login by username in Django admin, regardless of `allauth` "django.contrib.auth.backends.ModelBackend", # Allauth specific authentication methods, such as login by e-mail "allauth.account.auth_backends.AuthenticationBackend", ] WSGI_APPLICATION = "core.wsgi.application" # Database # https://docs.djangoproject.com/en/4.2/ref/settings/#databases DATABASES = { "default": env.db(), } # Password validation # https://docs.djangoproject.com/en/4.2/ref/settings/#auth-password-validators AUTH_PASSWORD_VALIDATORS = [ { "NAME": "django.contrib.auth.password_validation.UserAttributeSimilarityValidator", }, { "NAME": "django.contrib.auth.password_validation.MinimumLengthValidator", }, { "NAME": "django.contrib.auth.password_validation.CommonPasswordValidator", }, { "NAME": "django.contrib.auth.password_validation.NumericPasswordValidator", }, ] # Internationalization # https://docs.djangoproject.com/en/4.2/topics/i18n/ LANGUAGE_CODE = "de-de" TIME_ZONE = "Europe/Berlin" USE_I18N = True USE_TZ = True # Static files (CSS, JavaScript, Images) # https://docs.djangoproject.com/en/4.2/howto/static-files/ STATIC_URL = "static/" STATICFILES_DIRS = [BASE_DIR / "static"] STATIC_ROOT = BASE_DIR / "staticfiles" STATICFILES_STORAGE = "whitenoise.storage.CompressedManifestStaticFilesStorage" # Default primary key field type # https://docs.djangoproject.com/en/4.2/ref/settings/#default-auto-field DEFAULT_AUTO_FIELD = "django.db.models.BigAutoField" # Crispy forms CRISPY_ALLOWED_TEMPLATE_PACKS = "bootstrap5" CRISPY_TEMPLATE_PACK = "bootstrap5" # Allauth SITE_ID = 1 ACCOUNT_AUTHENTICATION_METHOD = "username_email" ACCOUNT_EMAIL_REQUIRED = True ACCOUNT_EMAIL_VERIFICATION = "mandatory" ACCOUNT_LOGIN_ATTEMPTS_LIMIT = 5 ACCOUNT_LOGIN_ATTEMPTS_TIMEOUT = 86400 # 1 day in seconds ACCOUNT_LOGIN_ON_EMAIL_CONFIRMATION = True ACCOUNT_LOGOUT_REDIRECT_URL = "/" ACCOUNT_LOGOUT_ON_GET = True ACCOUNT_SESSION_REMEMBER = True ACCOUNT_USERNAME_BLACKLIST = ["admin", "god"] ACCOUNT_USERNAME_MIN_LENGTH = 3 ACCOUNT_UNIQUE_EMAIL = True LOGIN_REDIRECT_URL = "/bird/all" # Email EMAIL_BACKEND = "django.core.mail.backends.console.EmailBackend" JAZZMIN_SETTINGS = { # title of the window (Will default to current_admin_site.site_title if absent or None) "site_title": "FBF Admin", # Title on the login screen (19 chars max) (defaults to current_admin_site.site_header if absent or None) "site_header": "Fallen Birdy App", # Title on the brand (19 chars max) (defaults to current_admin_site.site_header if absent or None) "site_brand": "Fallen Birdy App", # Logo to use for your site, must be present in static files, used for brand on top left # "site_logo": "img/wvhLogo.svg", # Logo to use for your site, must be present in static files, used for login form logo (defaults to site_logo) "login_logo": None, # Logo to use for login form in dark themes (defaults to login_logo) "login_logo_dark": None, # CSS classes that are applied to the logo above "site_logo_classes": "img-circle", # Relative path to a favicon for your site, will default to site_logo if absent (ideally 32x32 px) "site_icon": None, # Welcome text on the login screen "welcome_sign": "Willkommen bei der FBF-App im Admin-Bereich", # Copyright on the footer # "copyright": "Acme Library Ltd", # List of model admins to search from the search bar, search bar omitted if excluded # If you want to use a single search field you dont need to use a list, you can use a simple string "search_model": ["auth.User", "auth.Group"], # Field name on user model that contains avatar ImageField/URLField/Charfield or a callable that receives the user "user_avatar": None, ############ # Top Menu # ############ # Links to put along the top menu "topmenu_links": [ # Url that gets reversed (Permissions can be added) # {"name": "Home", "url": "admin:index", "permissions": ["auth.view_user"]}, # external url that opens in a new window (Permissions can be added) # {"name": "Support", "url": "https://github.com/farridav/django-jazzmin/issues", "new_window": True}, # model admin to link to (Permissions checked against model) {"model": "auth.User"}, # App with dropdown menu to all its models pages (Permissions checked against models) # {"app": "books"}, ], ############# # User Menu # ############# # Additional links to include in the user menu on the top right ("app" url type is not allowed) # "usermenu_links": [ # {"name": "Support", "url": "https://github.com/farridav/django-jazzmin/issues", "new_window": True}, # {"model": "auth.user"} # ], ############# # Side Menu # ############# # Whether to display the side menu "show_sidebar": True, # Whether to aut expand the menu "navigation_expanded": True, # Hide these apps when generating side menu e.g (auth) # "hide_apps": [], # Hide these models when generating side menu (e.g auth.user) # "hide_models": [], # List of apps (and/or models) to base side menu ordering off of (does not need to contain all apps/models) # "order_with_respect_to": ["auth", "books", "books.author", "books.book"], # Custom links to append to app groups, keyed on app name # "custom_links": { # "books": [{ # "name": "Make Messages", # "url": "make_messages", # "icon": "fas fa-comments", # "permissions": ["books.view_book"] # }] # }, # Custom icons for side menu apps/models See https://fontawesome.com/icons?d=gallery&m=free&v=5.0.0,5.0.1,5.0.10,5.0.11,5.0.12,5.0.13,5.0.2,5.0.3,5.0.4,5.0.5,5.0.6,5.0.7,5.0.8,5.0.9,5.1.0,5.1.1,5.2.0,5.3.0,5.3.1,5.4.0,5.4.1,5.4.2,5.13.0,5.12.0,5.11.2,5.11.1,5.10.0,5.9.0,5.8.2,5.8.1,5.7.2,5.7.1,5.7.0,5.6.3,5.5.0,5.4.2 # for the full list of 5.13.0 free icon classes # "icons": { # "auth": "fas fa-users-cog", # "auth.user": "fas fa-user", # "auth.Group": "fas fa-users", # }, # Icons that are used when one is not manually specified # "default_icon_parents": "fas fa-chevron-circle-right", # "default_icon_children": "fas fa-circle", ################# # Related Modal # ################# # Use modals instead of popups # "related_modal_active": False, ############# # UI Tweaks # ############# # Relative paths to custom CSS/JS scripts (must be present in static files) # "custom_css": None, # "custom_js": None, # Whether to link font from fonts.googleapis.com (use custom_css to supply font otherwise) "use_google_fonts_cdn": True, # Whether to show the UI customizer on the sidebar "show_ui_builder": True, ############### # Change view # ############### # Render out the change view as a single form, or in tabs, current options are # - single # - horizontal_tabs (default) # - vertical_tabs # - collapsible # - carousel "changeform_format": "horizontal_tabs", # override change forms on a per modeladmin basis "changeform_format_overrides": { "auth.user": "collapsible", "auth.group": "vertical_tabs", }, # Add a language dropdown into the admin # "language_chooser": True, }