""" Django settings for core project. Generated by 'django-admin startproject' using Django 6.0.2. For more information on this file, see https://docs.djangoproject.com/en/6.0/topics/settings/ For the full list of settings and their values, see https://docs.djangoproject.com/en/6.0/ref/settings/ """ from pathlib import Path import os import environ # Build paths inside the project like this: BASE_DIR / 'subdir'. BASE_DIR = Path(__file__).resolve().parent.parent env = environ.Env() environ.Env.read_env(BASE_DIR / '.env') # Quick-start development settings - unsuitable for production # See https://docs.djangoproject.com/en/6.0/howto/deployment/checklist/ # SECURITY WARNING: keep the secret key used in production secret! SECRET_KEY = env('SECRET_KEY', default='django-insecure-FxIJkTCbCfj9VRywq1beYkfHqsbIB9RLqH7TxqyQJhvtceB9m8sfv04j15oHw2q0') # SECURITY WARNING: don't run with debug turned on in production! # DEBUG = env.bool('DEBUG', default=True) DEBUG = True ALLOWED_HOSTS = env.list( 'DJANGO_ALLOWED_HOSTS', default=['localhost', '127.0.0.1', 'web_beyhan', 'caddy_beyhan'], ) # Application definition INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', # Third-party apps 'rest_framework', 'rest_framework_simplejwt', 'drf_spectacular', # 'drf_spectacular_sidecar', 'djoser', 'corsheaders', 'django_filters', 'django_ckeditor_5', 'colorfield', 'social_django', 'django_celery_beat', 'django_celery_results', 'imagekit', 'django_cleanup', 'timezone_field', 'autoslug', 'tinymce', 'accounts', 'settings', 'blog', 'backup', ] MIDDLEWARE = [ 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'corsheaders.middleware.CorsMiddleware', # Added CorsMiddleware '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' SITE_ID = 1 TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [BASE_DIR / 'templates'] , 'APP_DIRS': True, 'OPTIONS': { 'context_processors': [ 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages', 'social_django.context_processors.backends', 'social_django.context_processors.login_redirect', ], }, }, ] WSGI_APPLICATION = 'core.wsgi.application' # Database # https://docs.djangoproject.com/en/6.0/ref/settings/#databases DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': env('MYSQL_DATABASE', default='dj_beyhan'), 'USER': env('MYSQL_USER', default='dj_beyhan'), 'PASSWORD': env('MYSQL_PASSWORD', default='gg7678290'), 'HOST': env('MYSQL_HOST', default='10.80.80.70'), 'PORT': env('MYSQL_PORT', default='3306'), # opsiyonel: kalıcı bağlantı (saniye), None = kapalı 'CONN_MAX_AGE': 600, 'OPTIONS': { 'init_command': "SET sql_mode='STRICT_TRANS_TABLES'", 'charset': 'utf8mb4', }, 'TEST': { 'CHARSET': 'utf8mb4', 'COLLATION': 'utf8mb4_general_ci', }, } } CACHES = { 'default': { 'BACKEND': 'django_redis.cache.RedisCache', # 'LOCATION': 'redis://default:1923btO**@ares-redis-xrot7z:6379', 'LOCATION': os.getenv('REDIS_URL', 'redis://default:gg7678290@10.80.80.70:6379'), # 'LOCATION': os.getenv('REDIS_URL', 'redis://127.0.0.1:6379/1'), 'OPTIONS': { 'CLIENT_CLASS': 'django_redis.client.DefaultClient', }, 'KEY_PREFIX': 'dj52', 'TIMEOUT': 300, # 5 dakika default timeout } } # Password validation # https://docs.djangoproject.com/en/6.0/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/6.0/topics/i18n/ # LANGUAGE_CODE = 'tr' # TIME_ZONE = 'Europe/Istanbul' LANGUAGE_CODE = 'en-us' TIME_ZONE = 'UTC' USE_I18N = True USE_TZ = True # Static files (CSS, JavaScript, Images) # https://docs.djangoproject.com/en/6.0/howto/static-files/ STATIC_URL = 'static/' STATIC_ROOT = BASE_DIR / 'staticfiles' STATICFILES_DIRS = [ BASE_DIR / 'static', ] # Media files (User uploaded files) MEDIA_URL = 'media/' MEDIA_ROOT = BASE_DIR / 'media' STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage' AUTH_USER_MODEL = 'accounts.CustomUser' # CKEditor 5 settings CKEDITOR_5_CONFIGS = { 'default': { 'toolbar': ['heading', '|', 'bold', 'italic', 'link', 'bulletedList', 'numberedList', 'blockQuote', 'imageUpload', ], } } # REST Framework settings REST_FRAMEWORK = { 'DEFAULT_AUTHENTICATION_CLASSES': ( 'rest_framework_simplejwt.authentication.JWTAuthentication', ), 'DEFAULT_SCHEMA_CLASS': 'drf_spectacular.openapi.AutoSchema', } SPECTACULAR_SETTINGS = { 'TITLE': 'Your Project API', 'DESCRIPTION': 'Your project description', 'VERSION': '1.0.0', 'SERVE_INCLUDE_SCHEMA': False, # OTHER SETTINGS } # Celery settings CELERY_BROKER_URL = env('CELERY_BROKER_URL', default='redis://localhost:6379/0') CELERY_RESULT_BACKEND = 'django-db' CELERY_ACCEPT_CONTENT = ['application/json'] CELERY_TASK_SERIALIZER = 'json' CELERY_RESULT_SERIALIZER = 'json' CELERY_TIMEZONE = TIME_ZONE CELERY_ENABLE_UTC = True # Celery'nin UTC kullanmasını zorla # django-celery-beat 2.1.0 expects pytz.localize; disable tz-aware mode for compatibility with zoneinfo. DJANGO_CELERY_BEAT_TZ_AWARE = False # CORS settings CORS_ALLOW_ALL_ORIGINS = True # For development only, configure properly for production