""" Django settings for _base project. Generated by 'django-admin startproject' using Django 5.2.4. For more information on this file, see https://docs.djangoproject.com/en/5.2/topics/settings/ For the full list of settings and their values, see https://docs.djangoproject.com/en/5.2/ref/settings/ """ import os from pathlib import Path from decouple import config import dj_database_url # 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/5.2/howto/deployment/checklist/ # SECURITY WARNING: keep the secret key used in production secret! SECRET_KEY = config('DJANGO_SECRET_KEY', default="unsecure-secretkey-kjhsgfjsfgjsfgjsg") # SECURITY WARNING: don't run with debug turned on in production! DEBUG = config('DEBUG', cast=bool, default=True) # Allowed hosts ALLOWED_HOSTS = [host for host in config("DJANGO_ALLOWED_HOSTS", default="").split() if host] # URL scheme (http or https) URL_SCHEME = config("URL_SCHEME", default="http") # CSRF trusted origins (add both with and without port if you use a non-standard port) CSRF_TRUSTED_ORIGINS = [] for host in ALLOWED_HOSTS: if host not in ("localhost", "127.0.0.1"): CSRF_TRUSTED_ORIGINS.append(f"{URL_SCHEME}://{host}") # Generate base URL for absolute URLs (use first allowed host) BASE_URL = f"{URL_SCHEME}://{ALLOWED_HOSTS[0]}" if ALLOWED_HOSTS else "http://localhost" # Application definition INSTALLED_APPS = [ # ------ theme ------ # 'jazzmin', # ------------------- # 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.contrib.humanize', # ------- third party apps ------- # 'simple_history', 'django_extensions', # -------------------------------- # # ------- my apps ------- # 'accounts.apps.AccountsConfig', 'locations.apps.LocationsConfig', 'wells.apps.WellsConfig', 'common.apps.CommonConfig', 'processes.apps.ProcessesConfig', 'invoices.apps.InvoicesConfig', 'contracts.apps.ContractsConfig', 'certificates.apps.CertificatesConfig', 'installations.apps.InstallationsConfig', # ----------------------- # ] MIDDLEWARE = [ 'django.middleware.security.SecurityMiddleware', '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', 'simple_history.middleware.HistoryRequestMiddleware', ] ROOT_URLCONF = '_base.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', 'common.context_processors.current_year', ], }, }, ] WSGI_APPLICATION = '_base.wsgi.application' # Database # https://docs.djangoproject.com/en/5.2/ref/settings/#databases DB_TYPE = config('DB_TYPE', default='sqlite').lower() if DB_TYPE == 'postgres': DATABASES = { 'default': dj_database_url.config(default=config('DATABASE_URL')) } else: DATABASES = { "default": { "ENGINE": "django.db.backends.sqlite3", "NAME": BASE_DIR/"db.sqlite3", } } # Password validation # https://docs.djangoproject.com/en/5.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/5.2/topics/i18n/ LANGUAGES = [ ('fa', 'Persian'), # ('en', 'English') ] LANGUAGE_CODE = 'fa-ir' TIME_ZONE = 'Asia/Tehran' USE_I18N = True USE_L10N = True USE_TZ = True # Static files (CSS, JavaScript, Images) STATIC_URL = '/static/' STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles') STATICFILES_DIRS = [ os.path.join(BASE_DIR, 'static'), ] # Media files MEDIA_URL = '/media/' MEDIA_ROOT = os.path.join(BASE_DIR, 'media') # Default primary key field type # https://docs.djangoproject.com/en/5.2/ref/settings/#default-auto-field DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField' JAZZMIN_SETTINGS = { # title of the window (Will default to current_admin_site.site_title if absent or None) "site_title": "سامانه شفافیت", # Title on the login screen (19 chars max) (defaults to current_admin_site.site_header if absent or None) "site_header": "سامانه شفافیت", # Title on the brand (19 chars max) (defaults to current_admin_site.site_header if absent or None) "site_brand": "سامانه شفافیت", # Welcome text on the login screen "welcome_sign": "به سامانه شفافیت خوش آمدید", # Copyright on the footer "copyright": "سامانه شفافیت", # Logo to use for your site, must be present in static files, used for brand on top left # "site_logo": "../static/dist/img/iconlogo.png", # Relative paths to custom CSS/JS scripts (must be present in static files) "custom_css": "../static/admin/css/custom_rtl.css", "custom_js": None, } # VAT / Value Added Tax percent (e.g., 0.09 for 9%) VAT_RATE = 0.1