settings.py 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424
  1. # pylint: disable=line-too-long
  2. """
  3. Django settings for dev project.
  4. Generated by 'django-admin startproject' using Django 1.11.15.
  5. For more information on this file, see
  6. https://docs.djangoproject.com/en/1.11/topics/settings/
  7. For the full list of settings and their values, see
  8. https://docs.djangoproject.com/en/1.11/ref/settings/
  9. """
  10. import os
  11. # Build paths inside the project like this: os.path.join(BASE_DIR, ...)
  12. BASE_DIR = os.path.dirname(os.path.abspath(__file__))
  13. # Define placeholder gettext function
  14. # This function will mark strings in settings visible to makemessages
  15. # without need for Django's i18n features be initialized first.
  16. _ = lambda s: s
  17. # Quick-start development settings - unsuitable for production
  18. # See https://docs.djangoproject.com/en/1.11/howto/deployment/checklist/
  19. # SECURITY WARNING: keep the secret key used in production secret!
  20. SECRET_KEY = "1znyfpwp*_#!r0#l248lht*6)_0b+504n*2-8cxf(2u)fhi0f^"
  21. # SECURITY WARNING: don't run with debug turned on in production!
  22. DEBUG = True
  23. # A list of strings representing the host/domain names that this Django site can serve.
  24. # If you are unsure, just enter here your domain name, eg. ['mysite.com', 'www.mysite.com']
  25. ALLOWED_HOSTS = []
  26. # Database
  27. # https://docs.djangoproject.com/en/1.11/ref/settings/#databases
  28. DATABASES = {
  29. "default": {
  30. # Misago requires PostgreSQL to run
  31. "ENGINE": "django.db.backends.postgresql",
  32. "NAME": os.environ.get("POSTGRES_DB"),
  33. "USER": os.environ.get("POSTGRES_USER"),
  34. "PASSWORD": os.environ.get("POSTGRES_PASSWORD"),
  35. "HOST": os.environ.get("POSTGRES_HOST"),
  36. "PORT": 5432,
  37. }
  38. }
  39. # Caching
  40. # https://docs.djangoproject.com/en/1.11/topics/cache/#setting-up-the-cache
  41. CACHES = {
  42. "default": {
  43. # Misago doesn't run well with LocMemCache in production environments
  44. "BACKEND": "django.core.cache.backends.locmem.LocMemCache"
  45. }
  46. }
  47. # Password validation
  48. # https://docs.djangoproject.com/en/1.11/ref/settings/#auth-password-validators
  49. AUTH_PASSWORD_VALIDATORS = [
  50. {
  51. "NAME": "django.contrib.auth.password_validation.UserAttributeSimilarityValidator",
  52. "OPTIONS": {"user_attributes": ["username", "email"]},
  53. },
  54. {
  55. "NAME": "django.contrib.auth.password_validation.MinimumLengthValidator",
  56. "OPTIONS": {"min_length": 7},
  57. },
  58. {"NAME": "django.contrib.auth.password_validation.CommonPasswordValidator"},
  59. {"NAME": "django.contrib.auth.password_validation.NumericPasswordValidator"},
  60. ]
  61. # Internationalization
  62. # https://docs.djangoproject.com/en/1.11/topics/i18n/
  63. LANGUAGE_CODE = "en-us"
  64. TIME_ZONE = "UTC"
  65. USE_I18N = True
  66. USE_L10N = True
  67. USE_TZ = True
  68. # Static files (CSS, JavaScript, Images)
  69. # https://docs.djangoproject.com/en/1.11/howto/static-files/
  70. STATIC_URL = "/static/"
  71. # User uploads (Avatars, Attachments, files uploaded in other Django apps, ect.)
  72. # https://docs.djangoproject.com/en/1.11/howto/static-files/
  73. MEDIA_URL = "/media/"
  74. # The absolute path to the directory where collectstatic will collect static files for deployment.
  75. # https://docs.djangoproject.com/en/1.11/ref/settings/#static-root
  76. STATIC_ROOT = os.path.join(BASE_DIR, "static")
  77. # Absolute filesystem path to the directory that will hold user-uploaded files.
  78. # https://docs.djangoproject.com/en/1.11/ref/settings/#media-root
  79. MEDIA_ROOT = os.path.join(BASE_DIR, "media")
  80. # This setting defines the additional locations the staticfiles app will traverse if the FileSystemFinder finder
  81. # is enabled, e.g. if you use the collectstatic or findstatic management command or use the static file serving view.
  82. # https://docs.djangoproject.com/en/1.10/ref/settings/#staticfiles-dirs
  83. STATICFILES_DIRS = []
  84. # Email configuration
  85. # https://docs.djangoproject.com/en/1.11/ref/settings/#email-backend
  86. EMAIL_HOST = "localhost"
  87. EMAIL_PORT = 25
  88. # If either of these settings is empty, Django won't attempt authentication.
  89. EMAIL_HOST_USER = ""
  90. EMAIL_HOST_PASSWORD = ""
  91. # Default email address to use for various automated correspondence from the site manager(s).
  92. DEFAULT_FROM_EMAIL = "Forums <%s>" % EMAIL_HOST_USER
  93. # Application definition
  94. AUTH_USER_MODEL = "misago_users.User"
  95. AUTHENTICATION_BACKENDS = ["misago.users.authbackends.MisagoBackend"]
  96. CSRF_FAILURE_VIEW = "misago.core.errorpages.csrf_failure"
  97. INSTALLED_APPS = [
  98. # Misago overrides for Django core feature
  99. "misago",
  100. "misago.users",
  101. # Django apps
  102. "django.contrib.admin",
  103. "django.contrib.auth",
  104. "django.contrib.contenttypes",
  105. "django.contrib.postgres",
  106. "django.contrib.humanize",
  107. "django.contrib.sessions",
  108. "django.contrib.messages",
  109. "django.contrib.staticfiles",
  110. # 3rd party apps used by Misago
  111. "ariadne.contrib.django",
  112. "celery",
  113. "debug_toolbar",
  114. "mptt",
  115. "rest_framework",
  116. "social_django",
  117. # Misago apps
  118. "misago.admin",
  119. "misago.acl",
  120. "misago.analytics",
  121. "misago.cache",
  122. "misago.core",
  123. "misago.conf",
  124. "misago.icons",
  125. "misago.themes",
  126. "misago.markup",
  127. "misago.legal",
  128. "misago.categories",
  129. "misago.threads",
  130. "misago.readtracker",
  131. "misago.search",
  132. "misago.socialauth",
  133. "misago.graphql",
  134. "misago.faker",
  135. "misago.sso",
  136. ]
  137. INTERNAL_IPS = ["127.0.0.1"]
  138. LOGIN_REDIRECT_URL = "misago:index"
  139. LOGIN_URL = "misago:login"
  140. LOGOUT_URL = "misago:logout"
  141. MIDDLEWARE = [
  142. "debug_toolbar.middleware.DebugToolbarMiddleware",
  143. "misago.users.middleware.RealIPMiddleware",
  144. "misago.core.middleware.FrontendContextMiddleware",
  145. "django.middleware.security.SecurityMiddleware",
  146. "django.contrib.sessions.middleware.SessionMiddleware",
  147. "django.middleware.common.CommonMiddleware",
  148. "django.middleware.csrf.CsrfViewMiddleware",
  149. "django.contrib.auth.middleware.AuthenticationMiddleware",
  150. "django.contrib.messages.middleware.MessageMiddleware",
  151. "django.middleware.clickjacking.XFrameOptionsMiddleware",
  152. "misago.cache.middleware.cache_versions_middleware",
  153. "misago.conf.middleware.dynamic_settings_middleware",
  154. "misago.socialauth.middleware.socialauth_providers_middleware",
  155. "misago.users.middleware.UserMiddleware",
  156. "misago.acl.middleware.user_acl_middleware",
  157. "misago.core.middleware.ExceptionHandlerMiddleware",
  158. "misago.users.middleware.OnlineTrackerMiddleware",
  159. "misago.admin.middleware.AdminAuthMiddleware",
  160. "misago.threads.middleware.UnreadThreadsCountMiddleware",
  161. ]
  162. ROOT_URLCONF = "devproject.urls"
  163. SOCIAL_AUTH_STRATEGY = "misago.socialauth.strategy.MisagoStrategy"
  164. SOCIAL_AUTH_PIPELINE = (
  165. # Steps required by social pipeline to work - don't delete those!
  166. "social_core.pipeline.social_auth.social_details",
  167. "social_core.pipeline.social_auth.social_uid",
  168. "social_core.pipeline.social_auth.social_user",
  169. # If enabled in admin panel, lets your users to associate their old forum account
  170. # with social one, if both have same e-mail address.
  171. "misago.socialauth.pipeline.associate_by_email",
  172. # Those steps make sure banned users may not join your site or use banned name or email.
  173. "misago.socialauth.pipeline.validate_ip_not_banned",
  174. "misago.socialauth.pipeline.validate_user_not_banned",
  175. # Reads user data received from social site and tries to create valid and available username
  176. # Required if you want automatic account creation to work. Otherwise optional.
  177. "misago.socialauth.pipeline.get_username",
  178. # Uncomment next line to enable automatic account creation if data from social site is valid
  179. # and get_username found valid name for new user account:
  180. # 'misago.socialauth.pipeline.create_user',
  181. # This step asks user to complete simple, pre filled registration form containing username,
  182. # email, legal note if you remove it without adding custom one, users will have no fallback
  183. # for joining your site using their social account.
  184. "misago.socialauth.pipeline.create_user_with_form",
  185. # Steps finalizing social authentication flow - don't delete those!
  186. "social_core.pipeline.social_auth.associate_user",
  187. "social_core.pipeline.social_auth.load_extra_data",
  188. "misago.socialauth.pipeline.require_activation",
  189. )
  190. SOCIAL_AUTH_POSTGRES_JSONFIELD = True
  191. TEMPLATES = [
  192. {
  193. "BACKEND": "django.template.backends.django.DjangoTemplates",
  194. "DIRS": [],
  195. "APP_DIRS": True,
  196. "OPTIONS": {
  197. "context_processors": [
  198. "django.template.context_processors.debug",
  199. "django.template.context_processors.i18n",
  200. "django.template.context_processors.media",
  201. "django.template.context_processors.request",
  202. "django.template.context_processors.static",
  203. "django.template.context_processors.tz",
  204. "django.contrib.auth.context_processors.auth",
  205. "django.contrib.messages.context_processors.messages",
  206. "misago.acl.context_processors.user_acl",
  207. "misago.conf.context_processors.conf",
  208. "misago.conf.context_processors.og_image",
  209. "misago.core.context_processors.misago_version",
  210. "misago.core.context_processors.request_path",
  211. "misago.core.context_processors.momentjs_locale",
  212. "misago.icons.context_processors.icons",
  213. "misago.search.context_processors.search_providers",
  214. "misago.themes.context_processors.theme",
  215. "misago.legal.context_processors.legal_links",
  216. "misago.users.context_processors.user_links",
  217. # Data preloaders
  218. "misago.conf.context_processors.preload_settings_json",
  219. "misago.core.context_processors.current_link",
  220. "misago.markup.context_processors.preload_api_url",
  221. "misago.threads.context_processors.preload_threads_urls",
  222. "misago.users.context_processors.preload_user_json",
  223. "misago.socialauth.context_processors.preload_socialauth_json",
  224. # Note: keep frontend_context processor last for previous processors
  225. # to be able to expose data UI app via request.frontend_context
  226. "misago.core.context_processors.frontend_context",
  227. ]
  228. },
  229. }
  230. ]
  231. WSGI_APPLICATION = "devproject.wsgi.application"
  232. # Django Debug Toolbar
  233. # http://django-debug-toolbar.readthedocs.io/en/stable/configuration.html
  234. DEBUG_TOOLBAR_PANELS = [
  235. "debug_toolbar.panels.versions.VersionsPanel",
  236. "debug_toolbar.panels.timer.TimerPanel",
  237. "debug_toolbar.panels.settings.SettingsPanel",
  238. "debug_toolbar.panels.headers.HeadersPanel",
  239. "debug_toolbar.panels.request.RequestPanel",
  240. "debug_toolbar.panels.sql.SQLPanel",
  241. "misago.acl.panels.MisagoACLPanel",
  242. "debug_toolbar.panels.staticfiles.StaticFilesPanel",
  243. "debug_toolbar.panels.templates.TemplatesPanel",
  244. "debug_toolbar.panels.cache.CachePanel",
  245. "debug_toolbar.panels.signals.SignalsPanel",
  246. "debug_toolbar.panels.logging.LoggingPanel",
  247. ]
  248. # Django Rest Framework
  249. # http://www.django-rest-framework.org/api-guide/settings/
  250. REST_FRAMEWORK = {
  251. "DEFAULT_PERMISSION_CLASSES": [
  252. "misago.core.rest_permissions.IsAuthenticatedOrReadOnly"
  253. ],
  254. "DEFAULT_RENDERER_CLASSES": ["rest_framework.renderers.JSONRenderer"],
  255. "EXCEPTION_HANDLER": "misago.core.exceptionhandler.handle_api_exception",
  256. "UNAUTHENTICATED_USER": "misago.users.models.AnonymousUser",
  257. "URL_FORMAT_OVERRIDE": None,
  258. }
  259. # Celery - Distributed Task Queue
  260. # http://docs.celeryproject.org/en/latest/userguide/configuration.html
  261. # Configure Celery to use Redis as message broker.
  262. CELERY_BROKER_URL = "redis://redis:6379/0"
  263. # Celery workers may leak the memory, eventually depriving the instance of resources.
  264. # This setting forces celery to stop worker, clean after it and create new one
  265. # after worker has processed 10 tasks.
  266. CELERY_WORKER_MAX_TASKS_PER_CHILD = 10
  267. # Misago specific settings
  268. # https://misago.readthedocs.io/en/latest/developers/settings.html
  269. # On dev instance, generate only three sizes of avatars instead of default 6 sizes.
  270. MISAGO_AVATARS_SIZES = [400, 200, 100]
  271. # PostgreSQL text search configuration to use in searches
  272. # Defaults to "simple", for list of installed configurations run "\dF" in "psql".
  273. # Standard configs as of PostgreSQL 9.5 are: dutch, english, finnish, french,
  274. # german, hungarian, italian, norwegian, portuguese, romanian, russian, simple,
  275. # spanish, swedish and turkish
  276. # Example on adding custom language can be found here: https://github.com/lemonskyjwt/plpstgrssearch
  277. MISAGO_SEARCH_CONFIG = "simple"
  278. # Path to the directory that Misago should use to prepare user data downloads.
  279. # Should not be accessible from internet.
  280. MISAGO_USER_DATA_DOWNLOADS_WORKING_DIR = os.path.join(BASE_DIR, "userdata")
  281. # Path to directory containing avatar galleries
  282. # Those galleries can be loaded by running loadavatargallery command
  283. MISAGO_AVATAR_GALLERY = os.path.join(BASE_DIR, "avatargallery")
  284. # Profile fields
  285. MISAGO_PROFILE_FIELDS = [
  286. {
  287. "name": _("Personal"),
  288. "fields": [
  289. "misago.users.profilefields.default.RealNameField",
  290. "misago.users.profilefields.default.GenderField",
  291. "misago.users.profilefields.default.BioField",
  292. "misago.users.profilefields.default.LocationField",
  293. ],
  294. },
  295. {
  296. "name": _("Contact"),
  297. "fields": [
  298. "misago.users.profilefields.default.TwitterHandleField",
  299. "misago.users.profilefields.default.SkypeIdField",
  300. "misago.users.profilefields.default.WebsiteField",
  301. ],
  302. },
  303. {
  304. "name": _("IP address"),
  305. "fields": ["misago.users.profilefields.default.JoinIpField"],
  306. },
  307. ]
  308. # Set dev instance to send e-mails to console
  309. EMAIL_BACKEND = "django.core.mail.backends.console.EmailBackend"
  310. # Display debug toolbar if IN_MISAGO_DOCKER enviroment var is set to "1"
  311. DEBUG_TOOLBAR_CONFIG = {
  312. "SHOW_TOOLBAR_CALLBACK": "misago.conf.debugtoolbar.enable_debug_toolbar"
  313. }
  314. # SECURITY WARNING: keep the private key used in production secret!
  315. SSO_PRIVATE_KEY = None # This key should be secret (max 64 chars)
  316. SSO_PUBLIC_KEY = None # This key may be public (max 64 chars)
  317. SSO_SERVER = "http://www.example.com/server/"