"" "
Django settings for blink_crm_api project.
Generated by 'django-admin startproject' using Django 3.1.3.
For more information on this file, see
https://d...content-available-to-author-only...t.com/en/3.1/topics/settings/
For the full list of settings and their values, see
https://d...content-available-to-author-only...t.com/en/3.1/ref/settings/
" ""
from pathlib import Path
import os
import socket
import sys
from datetime import timedelta
import dj_database_url
import sentry_sdk
from sentry_sdk.integrations .django import DjangoIntegration
from django.conf import settings
from firebase_admin import initialize_app
from notification.services .slack_service import SlackService
from core import config
import django
from django.utils .translation import gettext
django.utils .translation .ugettext = gettext
# sentry_sdk.init(
# dsn=os.environ.get('SENTRY_DSN', ''),
# integrations=[DjangoIntegration()],
# # Set traces_sample_rate to 1.0 to capture 100%
# # of transactions for performance monitoring.
# # We recommend adjusting this value in production.
# traces_sample_rate=0.1,
# # If you wish to associate users to errors (assuming you are using
# # django.contrib.auth) you may enable sending PII data.
# send_default_pii=True
# )
# 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://d...content-available-to-author-only...t.com/en/3.1/howto/deployment/checklist/
# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = 'wnia2ie9-(c2_)4g%ck%bw6lyfjtdgf@imcg*xe*n!uo%1^&0%'
# SECURITY WARNING: don't run with debug turned on in production!
DEBUG
= os.
getenv ( 'DEBUG' , False
) == 'True'
ALLOWED_HOSTS = [
'*'
]
print( '_________________THE PLATFORM IS _________' )
print( '_____________' + os.environ .get ( 'PLATFORM' , '' ) + '___________________' )
# Application definition
MIGRATION_COMMAND = sys.argv [ 1 ] in (
'makemigrations' , 'migrate' , 'loaddata' , 'import_coa_blink' , 'import_entry_templates' )
INSTALLED_APPS = [
"django.contrib.admin.apps.SimpleAdminConfig" if MIGRATION_COMMAND else 'django.contrib.admin' ,
'django.contrib.auth' ,
'django.contrib.contenttypes' ,
'django.contrib.sessions' ,
'django.contrib.messages' ,
'django.contrib.postgres' ,
'whitenoise.runserver_nostatic' ,
'django.contrib.staticfiles' ,
'drf_yasg' ,
'rest_framework' ,
'django_reactive' ,
'mathfilters' ,
'crm_app.apps.CrmAppConfig' ,
'ekyc_app.apps.EkycAppConfig' ,
'auth_app.apps.AuthAppConfig' ,
'datasets.apps.DatasetsConfig' ,
'ledger' ,
'lms.apps.LmsConfig' ,
'loan_app.apps.LoanAppConfig' ,
'reports_app.apps.ReportsAppConfig' ,
'payments.apps.PaymentsConfig' ,
"fcm_django" ,
'notification.apps.NotificationConfig' ,
'django_extensions' ,
'polymorphic' ,
'import_export' ,
'django_filters' ,
'rest_framework_simplejwt.token_blacklist' ,
'django_summernote' ,
'rangefilter' ,
'storages' ,
'call_center' ,
'elasticapm.contrib.django' ,
'credit_alerts' ,
'flutter_consumer' ,
'credit_app' ,
'merchant_dashboard' ,
'configurations' ,
'ticket_app' ,
'settlement_dashboard' ,
'tms_app' ,
'newEkyc_app' ,
'call_centerv2' ,
'ticket_appV2' ,
'archive_app' ,
'new_lms' ,
'log_app' ,
'collection' ,
'sales_tracking' ,
'django_rename_app' ,
'django_celery_results' ,
]
MIDDLEWARE = [
'django.middleware.locale.LocaleMiddleware' ,
'django.middleware.security.SecurityMiddleware' ,
'django.contrib.sessions.middleware.SessionMiddleware' ,
'corsheaders.middleware.CorsMiddleware' ,
'django.middleware.common.CommonMiddleware' ,
'django.middleware.csrf.CsrfViewMiddleware' ,
'django.contrib.auth.middleware.AuthenticationMiddleware' ,
'django.contrib.messages.middleware.MessageMiddleware' ,
'django.middleware.clickjacking.XFrameOptionsMiddleware' ,
'whitenoise.middleware.WhiteNoiseMiddleware' ,
# Timezone
"core.timezone_middleware.TimezoneMiddleware" ,
# Translation
"core.translation_middleware.TranslationMiddleware" ,
'elasticapm.contrib.django.middleware.TracingMiddleware'
]
ROOT_URLCONF = 'blink_crm_api.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' ,
'core.context_processors.from_settings'
] ,
} ,
} ,
]
WSGI_APPLICATION = 'blink_crm_api.wsgi.application'
# Database
# https://d...content-available-to-author-only...t.com/en/3.1/ref/settings/#databases
DATABASES = {
'default' : {
'ENGINE' : 'django.db.backends.sqlite3' ,
'NAME' : BASE_DIR / 'db.sqlite3' ,
}
}
if os.environ .get ( 'DATABASE_URL' ) :
print( 'found env database' )
print( os.environ .get ( 'DATABASE_URL' ) )
DATABASES = { 'default' : dj_database_url.config ( conn_max_age= 600 ) }
if "test" in sys.argv :
DATABASES[ "default" ] = {
"ENGINE" : "django.db.backends.postgresql" ,
"NAME" : "test_db" ,
"USER" : "postgres" ,
"PASSWORD" : "1234" ,
"HOST" : "localhost" ,
"PORT" : "5432" ,
}
AUTH_USER_MODEL = 'auth_app.User'
# Password validation
# https://d...content-available-to-author-only...t.com/en/3.1/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://d...content-available-to-author-only...t.com/en/3.1/topics/i18n/
LANGUAGES = [
( 'en' , 'English' ) ,
( 'ar' , 'Arabic' ) ,
]
# LANGUAGE_CODE = 'en-us'
LANGUAGE_CODE = 'ar'
TIME_ZONE = 'UTC'
USE_I18N = True
USE_L10N = True
USE_TZ = True
LOCALE_PATHS = (
os.path .join ( BASE_DIR, 'locale/' ) ,
)
# Static files (CSS, JavaScript, Images)
# https://d...content-available-to-author-only...t.com/en/3.1/howto/static-files/
PROJECT_DIR = os.path .dirname ( os.path .abspath ( __file__) )
STATIC_ROOT = os.path .join ( BASE_DIR, 'staticfiles' )
STATIC_URL = '/static/'
STATICFILES_DIRS = [
os.path .join ( BASE_DIR, 'static' ) ,
]
DATA_UPLOAD_MAX_MEMORY_SIZE= 4194304 #4 MB
CHECK_CONSUMER_RATE
= os.
getenv ( "CHECK_CONSUMER_RATE" , "5/day" )
REST_FRAMEWORK = {
'DEFAULT_AUTHENTICATION_CLASSES' : (
'rest_framework_simplejwt.authentication.JWTAuthentication' ,
) ,
'EXCEPTION_HANDLER' : 'core.exception_handler.exception_handler' ,
'DEFAULT_THROTTLE_RATES' : {
'check_consumer_daily' : CHECK_CONSUMER_RATE,
}
}
SWAGGER_SETTINGS = {
'SECURITY_DEFINITIONS' : {
'Bearer' : {
'type' : 'apiKey' ,
'name' : 'Authorization' ,
'in' : 'header'
}
}
}
SIMPLE_JWT = {
'ACCESS_TOKEN_LIFETIME' : timedelta( minutes= 30 ) ,
'REFRESH_TOKEN_LIFETIME' : timedelta( days= 5 ) ,
'ROTATE_REFRESH_TOKENS' : True,
'BLACKLIST_AFTER_ROTATION' : True,
'ALGORITHM' : 'HS256' ,
'SIGNING_KEY' : SECRET_KEY,
}
# FOR HTTPS
print( os.environ .get ( 'NOT_SECURE_CONNECTION' ) )
if os.environ .get ( 'NOT_SECURE_CONNECTION' ) :
print( 'Secure connection disabled' )
SESSION_COOKIE_SECURE = False
CSRF_COOKIE_SECURE = False
else :
SECURE_PROXY_SSL_HEADER = ( 'HTTP_X_FORWARDED_PROTO' , 'https' )
SESSION_COOKIE_SECURE = True
CSRF_COOKIE_SECURE = True
SECURE_SSL_REDIRECT = True
# Security Headers
SECURE_CONTENT_TYPE_NOSNIFF = True
SECURE_HSTS_INCLUDE_SUBDOMAINS = True
SECURE_HSTS_PRELOAD = True
SECURE_HSTS_SECONDS = 3600
# CORS
CORS_ALLOW_ALL_ORIGINS = True
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
EMAIL_HOST = 'smtp.gmail.com'
EMAIL_USE_TLS = True
EMAIL_PORT = 587
DEFAULT_FROM_EMAIL = os.environ .get ( 'EMAIL_HOST' , 'tech-alerts@blnk.ai' )
EMAIL_HOST_USER = os.environ .get ( 'EMAIL_HOST' , 'tech-alerts@blnk.ai' )
EMAIL_HOST_PASSWORD = os.environ .get ( 'EMAIL_PASSWORD' , 'jcvl kknv hdze eyvi' )
AWS_ACCESS_KEY_ID = os.environ .get ( 'AWS_ACCESS_KEY_ID' )
AWS_SECRET_ACCESS_KEY = os.environ .get ( 'AWS_SECRET_ACCESS_KEY' )
AWS_STORAGE_BUCKET_NAME = os.environ .get ( 'AWS_STORAGE_BUCKET_NAME' )
AWS_S3_REGION_NAME = os.environ .get ( 'AWS_REGION' )
AWS_S3_SIGNATURE_VERSION = 's3v4'
# SFTP - DJANGO_STORAGE
DEFAULT_FILE_STORAGE = 'storages.backends.sftpstorage.SFTPStorage'
SFTP_STORAGE_HOST = os.environ .get ( 'SFTP_STORAGE_HOST' , '' )
SFTP_STORAGE_ROOT = os.environ .get ( 'SFTP_STORAGE_ROOT' , '' )
#tel3et mohema metlasma
SFTP_STORAGE_PARAMS = {
'username' : os.environ .get ( 'SFTP_STORAGE_USERNAME' , '' ) ,
'password' : os.environ .get ( 'SFTP_STORAGE_PASS' , '' ) ,
'allow_agent' : False,
'look_for_keys' : False,
'timeout' : float ( os.environ .get ( 'SFTP_TIMEOUT' , '10.0' ) ) ,
'banner_timeout' : float ( os.environ .get ( 'SFTP_BANNER_TIMEOUT' , '10.0' ) ) ,
'auth_timeout' : float ( os.environ .get ( 'SFTP_AUTH_TIMEOUT' , '10.0' ) ) ,
}
SFTP_STORAGE_PARAM_BLNK_UPLOADS = {
'username' : os.environ .get ( 'SFTP_STORAGE_BLNK_UPLOADS_USERNAME' , '' ) ,
'password' : os.environ .get ( 'SFTP_STORAGE_BLNK_UPLOADS_PASS' , '' ) ,
'allow_agent' : False,
'look_for_keys' : False,
'timeout' : float ( os.environ .get ( 'SFTP_TIMEOUT' , '10.0' ) ) ,
'banner_timeout' : float ( os.environ .get ( 'SFTP_BANNER_TIMEOUT' , '10.0' ) ) ,
'auth_timeout' : float ( os.environ .get ( 'SFTP_AUTH_TIMEOUT' , '10.0' ) ) ,
}
# Text editor plugin
X_FRAME_OPTIONS = 'SAMEORIGIN'
SUMMERNOTE_CONFIG = {
# You can put custom Summernote settings
'summernote' : {
# Toolbar customization
# https://s...content-available-to-author-only...e.org/deep-dive/#custom-toolbar-popover
'toolbar' : [
[ 'view' , [ 'fullscreen' , 'codeview' ] ] ,
] ,
} ,
'js' : (
'/static/admin/summernote/custom.js' ,
) ,
}
# DATA_UPLOAD_MAX_NUMBER_FIELDS = None
FIREBASE_APP = initialize_app( )
FCM_DJANGO_SETTINGS = {
}
# FCM_DJANGO_SETTINGS = {
# "FCM_SERVER_KEY": os.environ.get('FCM_SERVER_KEY', ''),
# "FCM_SENDER_ID": os.environ.get('FCM_SENDER_ID', ''),
# }
if os.environ .get ( 'USE_X_FORWARDED_HOST' ) :
USE_X_FORWARDED_HOST = True
SECURE_PROXY_SSL_HEADER = ( 'HTTP_X_FORWARDED_PROTO' , 'https' )
# MEDIA_ROOT = "/NationalID/"
#MEDIA_URL = os.environ.get('SFTP_STORAGE_URL', '')
# LOGGING = {
# 'version': 1,
# 'disable_existing_loggers': False,
# 'handlers': {
# 'applogfile': {
# 'level': 'DEBUG',
# 'class': 'logging.FileHandler',
# 'filename': '../blnk_errors.log',
# 'maxBytes': 1024 * 1024 * 15, # 15MB
# 'backupCount': 10,
# },
# },
# 'loggers': {
# 'django': {
# 'handlers': ['applogfile','console'],
# 'level': 'DEBUG',
# },
# }
# }
# LOGGING = {
# 'version': 1,
# 'disable_existing_loggers': False,
# 'handlers': {
# 'applogfile': {
# 'level': 'DEBUG',
# 'class': 'logging.FileHandler',
# 'filename': '../blnk_errors.log',
# 'maxBytes': 1024 * 1024 * 15, # 15MB
# 'backupCount': 10,
# },
# },
# 'loggers': {
# 'django': {
# 'handlers': ['applogfile',],
# 'level': 'DEBUG',
# },
# }
# }
# LOGGING = {
# 'version': 1,
# 'disable_existing_loggers': False,
# 'handlers': {
# 'file': {
# 'level': 'DEBUG',
# 'class': 'logging.FileHandler',
# 'filename': '../blnk_errors.log',
# 'maxBytes': 1024 * 1024 * 15, # 15MB
# 'backupCount': 10,
# },
# },
# 'loggers': {
# 'django': {
# 'handlers': ['file'],
# 'level': 'DEBUG',
# # 'propagate': True,
# },
# },
# }
LOGGING = {
'version' : 1 ,
'disable_existing_loggers' : False,
'formatters' : {
'verbose' : {
'format' : '%(levelname)s %(asctime)s %(module)s %(process)d %(thread)d {server_ip} %(message)s'
} ,
} ,
'handlers' : {
'elasticapm' : {
'level' : 'DEBUG' ,
'class' : 'elasticapm.contrib.django.handlers.LoggingHandler' ,
} ,
'console' : {
'level' : 'DEBUG' ,
'class' : 'logging.StreamHandler' ,
'formatter' : 'verbose'
} ,
'to_slack' : {
'level' : 'DEBUG' ,
'formatter' : 'verbose' ,
'class' : 'core.custom_logging.CustomLoggingHandler' ,
'custom_function' : SlackService( os.environ .get ( 'API_ERROR_CHANNEL' ) ) .send_message
}
} ,
'loggers' : {
'mysite' : {
'level' : 'DEBUG' ,
'handlers' : [ 'elasticapm' ] ,
'propagate' : False,
} ,
# Log errors from the Elastic APM module to the console (recommended)
'elasticapm' : {
'level' : 'ERROR' ,
'handlers' : [ 'to_slack' , 'console' ] ,
'propagate' : False,
} ,
'crm_app' : {
'level' : 'DEBUG' ,
'handlers' : [ 'console' ] ,
'propagate' : False,
} ,
} ,
}
# Get the server's IP address
server_ip = socket.gethostbyname ( socket.gethostname ( ) )
LOGGING[ 'formatters' ] [ 'verbose' ] [ 'format' ] = LOGGING[ 'formatters' ] [ 'verbose' ] [ 'format' ] .replace ( '{server_ip}' , server_ip)
print( "APM CLOSE = " , os.environ .get ( 'APM_ClOSE_FLAG' , False) == 'True' )
ELASTIC_APM = {
# Set the required service name. Allowed characters:
# a-z, A-Z, 0-9, -, _, and space
'SERVICE_NAME' : 'django-test' ,
# Set the custom APM Server URL (default: http://localhost:8200)
'SERVER_URL' : os.environ .get ( 'APM_SERVER_URL' , '' ) ,
# Set the service environment
# 'DEBUG': os.environ.get('APM_ClOSE_FLAG',False) == 'True',
'DISABLE_SEND' : os.environ .get ( 'APM_ClOSE_FLAG' , True) == 'True' ,
'CAPTURE_BODY' : 'all' ,
'PROCESSORS' : [
'core.apm_processors.sanitize_processor' ,
'elasticapm.processors.sanitize_stacktrace_locals' ,
'elasticapm.processors.sanitize_http_request_cookies' ,
'elasticapm.processors.sanitize_http_headers' ,
'elasticapm.processors.sanitize_http_wsgi_env' ,
'elasticapm.processors.sanitize_http_request_body' ,
] ,
'INSTRUMENT' : True
}
CELERY_BROKER_URL = f'amqp://{config.RABBITMQ_USERNAME}:{config.RABBITMQ_PASSWORD}@{config.RABBITMQ_HOST}:{config.RABBITMQ_PORT}/{config.RABBITMQ_VIRTUAL_HOST}'
CELERY_RESULT_BACKEND = 'rpc://'
CELERY_ACCEPT_CONTENT = [ 'json' ]
CELERY_TASK_SERIALIZER = 'json'
CELERY_RESULT_SERIALIZER = 'json'
CELERY_TIMEZONE = 'UTC'
from urllib.parse import quote_plus
REDIS_HOST
= os.
getenv ( "REDIS_HOST" , "127.0.0.1" ) REDIS_PORT
= os.
getenv ( "REDIS_PORT" , "6379" ) REDIS_PASSWORD_RAW
= os.
getenv ( "REDIS_PASSWORD" , "" ) REDIS_DB
= os.
getenv ( "REDIS_DB" , "1" )
REDIS_PASSWORD = quote_plus( REDIS_PASSWORD_RAW)
REDIS_URL = f"redis://:{REDIS_PASSWORD}@{REDIS_HOST}:{REDIS_PORT}/{REDIS_DB}"
CACHES = {
"default" : {
"BACKEND" : "django_redis.cache.RedisCache" ,
"LOCATION" : REDIS_URL,
"OPTIONS" : {
"CLIENT_CLASS" : "django_redis.client.DefaultClient" ,
} ,
}
}
"""
Django settings for blink_crm_api project.

Generated by 'django-admin startproject' using Django 3.1.3.

For more information on this file, see
https://d...content-available-to-author-only...t.com/en/3.1/topics/settings/

For the full list of settings and their values, see
https://d...content-available-to-author-only...t.com/en/3.1/ref/settings/
"""

from pathlib import Path
import os
import socket
import sys
from datetime import timedelta
import dj_database_url
import sentry_sdk
from sentry_sdk.integrations.django import DjangoIntegration
from django.conf import settings
from firebase_admin import initialize_app
from notification.services.slack_service import SlackService

from core import config
import django
from django.utils.translation import gettext
django.utils.translation.ugettext = gettext

# sentry_sdk.init(
#     dsn=os.environ.get('SENTRY_DSN', ''),
#     integrations=[DjangoIntegration()],

#     # Set traces_sample_rate to 1.0 to capture 100%
#     # of transactions for performance monitoring.
#     # We recommend adjusting this value in production.
#     traces_sample_rate=0.1,

#     # If you wish to associate users to errors (assuming you are using
#     # django.contrib.auth) you may enable sending PII data.
#     send_default_pii=True
# )


# 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://d...content-available-to-author-only...t.com/en/3.1/howto/deployment/checklist/

# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = 'wnia2ie9-(c2_)4g%ck%bw6lyfjtdgf@imcg*xe*n!uo%1^&0%'

# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = os.getenv('DEBUG', False) == 'True'

ALLOWED_HOSTS = [
    '*'
]


print('_________________THE PLATFORM IS _________')
print('_____________' + os.environ.get('PLATFORM', '') + '___________________')


# Application definition
MIGRATION_COMMAND = sys.argv[1] in (
    'makemigrations', 'migrate', 'loaddata', 'import_coa_blink', 'import_entry_templates')
INSTALLED_APPS = [
    "django.contrib.admin.apps.SimpleAdminConfig" if MIGRATION_COMMAND else 'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.postgres',
    'whitenoise.runserver_nostatic',
    'django.contrib.staticfiles',
    'drf_yasg',
    'rest_framework',
    'django_reactive',
    'mathfilters',
    'crm_app.apps.CrmAppConfig',
    'ekyc_app.apps.EkycAppConfig',
    'auth_app.apps.AuthAppConfig',
    'datasets.apps.DatasetsConfig',
    'ledger',
    'lms.apps.LmsConfig',
    'loan_app.apps.LoanAppConfig',
    'reports_app.apps.ReportsAppConfig',
    'payments.apps.PaymentsConfig',
    "fcm_django",
    'notification.apps.NotificationConfig',
    'django_extensions',
    'polymorphic',
    'import_export',
    'django_filters',
    'rest_framework_simplejwt.token_blacklist',
    'django_summernote',
    'rangefilter',
    'storages',
    'call_center',
    'elasticapm.contrib.django',
    'credit_alerts',
    'flutter_consumer',
    'credit_app',
    'merchant_dashboard',
    'configurations',
    'ticket_app',
    'settlement_dashboard',
    'tms_app',
    'newEkyc_app',
    'call_centerv2',
    'ticket_appV2',
    'archive_app',
    'new_lms',
    'log_app',
    'collection',
    'sales_tracking',
    'django_rename_app',
    'django_celery_results',

]

MIDDLEWARE = [
    'django.middleware.locale.LocaleMiddleware',
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'corsheaders.middleware.CorsMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
    'whitenoise.middleware.WhiteNoiseMiddleware',
    # Timezone
    "core.timezone_middleware.TimezoneMiddleware",
    # Translation
    "core.translation_middleware.TranslationMiddleware",
    'elasticapm.contrib.django.middleware.TracingMiddleware'
]


ROOT_URLCONF = 'blink_crm_api.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',
                'core.context_processors.from_settings'
            ],
        },
    },
]

WSGI_APPLICATION = 'blink_crm_api.wsgi.application'

# Database
# https://d...content-available-to-author-only...t.com/en/3.1/ref/settings/#databases

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': BASE_DIR / 'db.sqlite3',
    }
}

if os.environ.get('DATABASE_URL'):
    print('found env database')
    print(os.environ.get('DATABASE_URL'))
    DATABASES = {'default': dj_database_url.config(conn_max_age=600)}

if "test" in sys.argv:
    DATABASES["default"] = {
        "ENGINE": "django.db.backends.postgresql",
        "NAME": "test_db",
        "USER": "postgres",
        "PASSWORD": "1234",
        "HOST": "localhost",
        "PORT": "5432",
    }

AUTH_USER_MODEL = 'auth_app.User'

# Password validation
# https://d...content-available-to-author-only...t.com/en/3.1/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://d...content-available-to-author-only...t.com/en/3.1/topics/i18n/

LANGUAGES = [
    ('en', 'English'),
    ('ar', 'Arabic'),
]


# LANGUAGE_CODE = 'en-us'

LANGUAGE_CODE = 'ar'
TIME_ZONE = 'UTC'

USE_I18N = True

USE_L10N = True

USE_TZ = True

LOCALE_PATHS = (
    os.path.join(BASE_DIR, 'locale/'),
)


# Static files (CSS, JavaScript, Images)
# https://d...content-available-to-author-only...t.com/en/3.1/howto/static-files/

PROJECT_DIR = os.path.dirname(os.path.abspath(__file__))

STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles')
STATIC_URL = '/static/'
STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'static'),
]
DATA_UPLOAD_MAX_MEMORY_SIZE=4194304 #4 MB

CHECK_CONSUMER_RATE = os.getenv("CHECK_CONSUMER_RATE", "5/day")

REST_FRAMEWORK = {
    'DEFAULT_AUTHENTICATION_CLASSES': (
        'rest_framework_simplejwt.authentication.JWTAuthentication',
    ),
    'EXCEPTION_HANDLER': 'core.exception_handler.exception_handler',
    'DEFAULT_THROTTLE_RATES': {
        'check_consumer_daily': CHECK_CONSUMER_RATE,
    }
}

SWAGGER_SETTINGS = {
    'SECURITY_DEFINITIONS': {
        'Bearer': {
            'type': 'apiKey',
            'name': 'Authorization',
            'in': 'header'
        }
    }
}

SIMPLE_JWT = {
    'ACCESS_TOKEN_LIFETIME': timedelta(minutes=30),
    'REFRESH_TOKEN_LIFETIME': timedelta(days=5),
    'ROTATE_REFRESH_TOKENS': True,
    'BLACKLIST_AFTER_ROTATION': True,
    'ALGORITHM': 'HS256',
    'SIGNING_KEY': SECRET_KEY,
}

# FOR HTTPS
print(os.environ.get('NOT_SECURE_CONNECTION'))
if os.environ.get('NOT_SECURE_CONNECTION'):
    print('Secure connection disabled')
    SESSION_COOKIE_SECURE = False
    CSRF_COOKIE_SECURE = False
else:
    SECURE_PROXY_SSL_HEADER = ('HTTP_X_FORWARDED_PROTO', 'https')
    SESSION_COOKIE_SECURE = True
    CSRF_COOKIE_SECURE = True
    SECURE_SSL_REDIRECT = True

    # Security Headers
    SECURE_CONTENT_TYPE_NOSNIFF = True
    SECURE_HSTS_INCLUDE_SUBDOMAINS = True
    SECURE_HSTS_PRELOAD = True
    SECURE_HSTS_SECONDS = 3600

# CORS
CORS_ALLOW_ALL_ORIGINS = True

EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
EMAIL_HOST = 'smtp.gmail.com'
EMAIL_USE_TLS = True
EMAIL_PORT = 587
DEFAULT_FROM_EMAIL = os.environ.get('EMAIL_HOST','tech-alerts@blnk.ai')
EMAIL_HOST_USER = os.environ.get('EMAIL_HOST','tech-alerts@blnk.ai')
EMAIL_HOST_PASSWORD = os.environ.get('EMAIL_PASSWORD','jcvl kknv hdze eyvi')


AWS_ACCESS_KEY_ID = os.environ.get('AWS_ACCESS_KEY_ID')
AWS_SECRET_ACCESS_KEY = os.environ.get('AWS_SECRET_ACCESS_KEY')
AWS_STORAGE_BUCKET_NAME = os.environ.get('AWS_STORAGE_BUCKET_NAME')

AWS_S3_REGION_NAME = os.environ.get('AWS_REGION')
AWS_S3_SIGNATURE_VERSION = 's3v4'

# SFTP - DJANGO_STORAGE
DEFAULT_FILE_STORAGE = 'storages.backends.sftpstorage.SFTPStorage'
SFTP_STORAGE_HOST = os.environ.get('SFTP_STORAGE_HOST', '')
SFTP_STORAGE_ROOT = os.environ.get('SFTP_STORAGE_ROOT', '')
#tel3et mohema metlasma
SFTP_STORAGE_PARAMS = {
    'username': os.environ.get('SFTP_STORAGE_USERNAME', ''),
    'password': os.environ.get('SFTP_STORAGE_PASS', ''),
    'allow_agent': False,
    'look_for_keys': False,
    'timeout': float(os.environ.get('SFTP_TIMEOUT', '10.0')),
    'banner_timeout': float(os.environ.get('SFTP_BANNER_TIMEOUT', '10.0')),
    'auth_timeout': float(os.environ.get('SFTP_AUTH_TIMEOUT', '10.0')),
}

SFTP_STORAGE_PARAM_BLNK_UPLOADS = {
    'username': os.environ.get('SFTP_STORAGE_BLNK_UPLOADS_USERNAME', ''),
    'password': os.environ.get('SFTP_STORAGE_BLNK_UPLOADS_PASS', ''),
    'allow_agent': False,
    'look_for_keys': False,
    'timeout': float(os.environ.get('SFTP_TIMEOUT', '10.0')),
    'banner_timeout': float(os.environ.get('SFTP_BANNER_TIMEOUT', '10.0')),
    'auth_timeout': float(os.environ.get('SFTP_AUTH_TIMEOUT', '10.0')),
}


# Text editor plugin
X_FRAME_OPTIONS = 'SAMEORIGIN'
SUMMERNOTE_CONFIG = {
    # You can put custom Summernote settings
    'summernote': {
        # Toolbar customization
        # https://s...content-available-to-author-only...e.org/deep-dive/#custom-toolbar-popover
        'toolbar': [
            ['view', ['fullscreen', 'codeview']],
        ],
    },
    'js': (
        '/static/admin/summernote/custom.js',
    ),
}

# DATA_UPLOAD_MAX_NUMBER_FIELDS = None

FIREBASE_APP = initialize_app()

FCM_DJANGO_SETTINGS = {

}
# FCM_DJANGO_SETTINGS = {
#     "FCM_SERVER_KEY": os.environ.get('FCM_SERVER_KEY', ''),
#     "FCM_SENDER_ID": os.environ.get('FCM_SENDER_ID', ''),
# }


if os.environ.get('USE_X_FORWARDED_HOST'):
    USE_X_FORWARDED_HOST = True
    SECURE_PROXY_SSL_HEADER = ('HTTP_X_FORWARDED_PROTO', 'https')

# MEDIA_ROOT = "/NationalID/"
#MEDIA_URL = os.environ.get('SFTP_STORAGE_URL', '')

# LOGGING = {
#     'version': 1,
#     'disable_existing_loggers': False,
#     'handlers': {
#         'applogfile': {
#             'level': 'DEBUG',
#             'class': 'logging.FileHandler',
#             'filename': '../blnk_errors.log',
#             'maxBytes': 1024 * 1024 * 15,  # 15MB
#             'backupCount': 10,
#         },
#     },
#     'loggers': {
#             'django': {
#                 'handlers': ['applogfile','console'],
#                 'level': 'DEBUG',
#             },
#         }
# }

# LOGGING = {
#     'version': 1,
#     'disable_existing_loggers': False,
#     'handlers': {
#         'applogfile': {
#             'level': 'DEBUG',
#             'class': 'logging.FileHandler',
#             'filename': '../blnk_errors.log',
#             'maxBytes': 1024 * 1024 * 15,  # 15MB
#             'backupCount': 10,
#         },
#     },
#     'loggers': {
#             'django': {
#                 'handlers': ['applogfile',],
#                 'level': 'DEBUG',
#             },
#         }
# }


# LOGGING = {
#     'version': 1,
#     'disable_existing_loggers': False,
#     'handlers': {
#         'file': {
#             'level': 'DEBUG',
#             'class': 'logging.FileHandler',
#             'filename': '../blnk_errors.log',
#             'maxBytes': 1024 * 1024 * 15,  # 15MB
#             'backupCount': 10,
#         },
#     },
#     'loggers': {
#         'django': {
#             'handlers': ['file'],
#             'level': 'DEBUG',
#             # 'propagate': True,
#         },
#     },
# }

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'formatters': {
        'verbose': {
            'format': '%(levelname)s %(asctime)s %(module)s %(process)d %(thread)d {server_ip} %(message)s'
        },
    },
    'handlers': {
        'elasticapm': {
            'level': 'DEBUG',
            'class': 'elasticapm.contrib.django.handlers.LoggingHandler',
        },
        'console': {
            'level': 'DEBUG',
            'class': 'logging.StreamHandler',
            'formatter': 'verbose'
        },
        'to_slack': {
            'level': 'DEBUG',
            'formatter': 'verbose',
            'class': 'core.custom_logging.CustomLoggingHandler',
            'custom_function': SlackService(os.environ.get('API_ERROR_CHANNEL')).send_message
        }
    },
    'loggers': {
        'mysite': {
            'level': 'DEBUG',
            'handlers': ['elasticapm'],
            'propagate': False,
        },
        # Log errors from the Elastic APM module to the console (recommended)
        'elasticapm': {
            'level': 'ERROR',
            'handlers': ['to_slack', 'console'],
            'propagate': False,
        },
        'crm_app': {
            'level': 'DEBUG',
            'handlers': [ 'console'],
            'propagate': False,
        },
    },
}

# Get the server's IP address
server_ip = socket.gethostbyname(socket.gethostname())
LOGGING['formatters']['verbose']['format'] = LOGGING['formatters']['verbose']['format'].replace('{server_ip}', server_ip)

print("APM CLOSE = ",os.environ.get('APM_ClOSE_FLAG',False) == 'True')
ELASTIC_APM = {
    # Set the required service name. Allowed characters:
    # a-z, A-Z, 0-9, -, _, and space
    'SERVICE_NAME': 'django-test',
    # Set the custom APM Server URL (default: http://localhost:8200)
    'SERVER_URL': os.environ.get('APM_SERVER_URL', ''),

    # Set the service environment

    # 'DEBUG': os.environ.get('APM_ClOSE_FLAG',False) == 'True',
    'DISABLE_SEND': os.environ.get('APM_ClOSE_FLAG',True) == 'True',
    'CAPTURE_BODY': 'all',
    'PROCESSORS': [
        'core.apm_processors.sanitize_processor',
        'elasticapm.processors.sanitize_stacktrace_locals',
        'elasticapm.processors.sanitize_http_request_cookies',
        'elasticapm.processors.sanitize_http_headers',
        'elasticapm.processors.sanitize_http_wsgi_env',
        'elasticapm.processors.sanitize_http_request_body',
    ],
    'INSTRUMENT': True
}

CELERY_BROKER_URL =  f'amqp://{config.RABBITMQ_USERNAME}:{config.RABBITMQ_PASSWORD}@{config.RABBITMQ_HOST}:{config.RABBITMQ_PORT}/{config.RABBITMQ_VIRTUAL_HOST}'
CELERY_RESULT_BACKEND = 'rpc://'

CELERY_ACCEPT_CONTENT = ['json']
CELERY_TASK_SERIALIZER = 'json'
CELERY_RESULT_SERIALIZER = 'json'
CELERY_TIMEZONE = 'UTC'

from urllib.parse import quote_plus

REDIS_HOST = os.getenv("REDIS_HOST", "127.0.0.1")
REDIS_PORT = os.getenv("REDIS_PORT", "6379")
REDIS_PASSWORD_RAW = os.getenv("REDIS_PASSWORD", "")
REDIS_DB = os.getenv("REDIS_DB", "1")

REDIS_PASSWORD = quote_plus(REDIS_PASSWORD_RAW)

REDIS_URL = f"redis://:{REDIS_PASSWORD}@{REDIS_HOST}:{REDIS_PORT}/{REDIS_DB}"

CACHES = {
    "default": {
        "BACKEND": "django_redis.cache.RedisCache",
        "LOCATION": REDIS_URL,
        "OPTIONS": {
            "CLIENT_CLASS": "django_redis.client.DefaultClient",
        },
    }
}