X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=myslice%2Fsettings.py;h=91584419c7b9dc7cb51864025c5408be818195ea;hb=fd13b08e5ae01e312431803eb1faf38a1589c4b9;hp=6c9d949c7e7c9977eb485d9881e75c7b75bee4f4;hpb=484b16eca194516c6a14ad1e000eeef24aa41fd6;p=myslice.git diff --git a/myslice/settings.py b/myslice/settings.py index 6c9d949c..91584419 100644 --- a/myslice/settings.py +++ b/myslice/settings.py @@ -1,29 +1,53 @@ # Django settings for myslice project. +import os.path + DEBUG = True TEMPLATE_DEBUG = DEBUG +# compute ROOT from where this file is installed +# should fit every need including developers +# but you can redefine ROOT if that's not working for you +try: + # get the directory where this file is + ROOT=os.path.dirname(__file__) or '.' + # move one step up + ROOT=os.path.realpath(ROOT+'/..') +except: + ROOT=None + if DEBUG: + import traceback + traceback.print_exc() + +if os.path.isdir(os.path.join(ROOT,"static")): + DATAROOT=ROOT +else: + DATAROOT="/usr/share/unfold" + if not os.path.isdir(os.path.join(DATAROOT,"static")): + DATAROOT=None + +if not ROOT: raise Exception,"Cannot find ROOT for myslice" +if not DATAROOT: raise Exception,"Cannot find DATAROOT for myslice" + +#################### ADMINS = ( - # ('Your Name', 'your_email@example.com'), + # ('your_name', 'your_email@test.com'), ) MANAGERS = ADMINS -## guess if we run on the 'prod' site (:) or on a working laptop -import os, os.path -ROOT='' -def init_root (): - global ROOT - if os.path.exists("/root/myslice"): - ROOT="/root/myslice" - else: - ROOT=os.path.expanduser("~/git/myslice-django") -init_root() +# Mail configuration +#DEFAULT_FROM_EMAIL = "root@theseus.ipv6.lip6.fr" +#EMAIL_HOST_PASSWORD = "mypassword" + +EMAIL_HOST = "localhost" +EMAIL_PORT = 25 +EMAIL_USE_TLS = False DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'. - 'NAME': os.path.join(ROOT,'myslice.sqlite3'), # Or path to database file if using sqlite3. + 'NAME': os.path.join(DATAROOT,'myslice.sqlite3'), # Or path to database file if using sqlite3. 'USER': '', # Not used with sqlite3. 'PASSWORD': '', # Not used with sqlite3. 'HOST': '', # Set to empty string for localhost. Not used with sqlite3. @@ -67,27 +91,47 @@ MEDIA_URL = '' # Don't put anything in this directory yourself; store your static files # in apps' "static/" subdirectories and in STATICFILES_DIRS. # Example: "/home/media/media.lawrence.com/static/" -STATIC_ROOT = os.path.join(ROOT,'all-static') +STATIC_ROOT = os.path.join(DATAROOT,'static') # URL prefix for static files. # Example: "http://media.lawrence.com/static/" -STATIC_URL = '/all-static/' +STATIC_URL = '/static/' # Additional locations of static files STATICFILES_DIRS = ( # Put strings here, like "/home/html/static" or "C:/www/django/static". # Always use forward slashes, even on Windows. # Don't forget to use absolute paths, not relative paths. + # Thierry : we do not need to detail the contents + # of our 'apps' since they're mentioned in INSTALLED_APPS ) +# Needed by PluginFinder +PLUGIN_DIR = os.path.join(ROOT,'plugins') +# ThirdPartyFinder +THIRDPARTY_DIR = os.path.join(ROOT, 'third-party') + # List of finder classes that know how to find static files in # various locations. STATICFILES_FINDERS = ( - 'django.contrib.staticfiles.finders.FileSystemFinder', +# Thierry : no need for this one +# 'django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder', -# 'django.contrib.staticfiles.finders.DefaultStorageFinder', + 'unfold.collectstatic.PluginFinder', + 'unfold.collectstatic.ThirdPartyFinder', +### 'django.contrib.staticfiles.finders.DefaultStorageFinder', ) +#TEMPLATE_CONTEXT_PROCESSORS = ( +# 'django.contrib.auth.context_processors.auth', +# 'django.core.context_processors.debug', +# 'django.core.context_processors.i18n', +# 'django.core.context_processors.media', +# 'django.core.context_processors.static', +# 'django.core.context_processors.request', +# 'django.contrib.messages.context_processors.messages', +#) + # Make this unique, and don't share it with anybody. SECRET_KEY = 't%n(3h)&r^n8(+8)(sp29t^$c2#t(m3)e2!02l8w1#36tl#t27' @@ -117,7 +161,7 @@ TEMPLATE_DIRS = ( # Put strings here, like "/home/html/django_templates" or "C:/www/django/templates". # Always use forward slashes, even on Windows. # Don't forget to use absolute paths, not relative paths. - os.path.join(ROOT,"templates"), + os.path.join(DATAROOT,"templates"), ) INSTALLED_APPS = ( @@ -127,13 +171,38 @@ INSTALLED_APPS = ( 'django.contrib.sites', 'django.contrib.messages', 'django.contrib.staticfiles', + # handling the {% insert %} and {% container %} tags + # see details in devel/django-insert-above-1.0-4 + 'insert_above', + # our django project 'myslice', + # the core of the UI + 'auth', 'manifold', 'unfold', + # plugins + 'plugins', + # views - more or less stable + 'ui', + # managing database migrations + 'south', # Uncomment the next line to enable the admin: # 'django.contrib.admin', # Uncomment the next line to enable admin documentation: # 'django.contrib.admindocs', + 'portal', + # temporary - not packaged + # 'trash', + 'sample', +# DEPRECATED # 'django.contrib.formtools', +# DEPRECATED ## 'crispy_forms', +# DEPRECATED # +# DEPRECATED # # User registration +# DEPRECATED # 'django.contrib.auth', +# DEPRECATED # 'django.contrib.sites', +# DEPRECATED # 'registration', ) +ACCOUNT_ACTIVATION_DAYS = 7 # One-week activation window; you may, of course, use a different value. + # A sample logging configuration. The only tangible logging # performed by this configuration is to send an email to # the site admins on every HTTP 500 error when DEBUG=False. @@ -163,4 +232,14 @@ LOGGING = { } } -AUTHENTICATION_BACKENDS = ( 'auth.backend.MyCustomBackend', ) +AUTHENTICATION_BACKENDS = ( 'auth.manifoldbackend.ManifoldBackend', ) + +### the view to redirect malformed (i.e. with a wrong CSRF) incoming requests +# without this setting django will return a 403 forbidden error, which is fine +# if you need to see the error message then use this setting +CSRF_FAILURE_VIEW = 'manifold.manifoldproxy.csrf_failure' + +#################### for insert_above +#IA_JS_FORMAT = "