X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=myslice%2Fsettings.py;h=17effaca3d6b552a2d31ac0f5b40d79eb0a5797d;hb=3a4354b6bfe461218ddd2c1bdb89f6051624d328;hp=4df98e2e60647905b8b7e3c6b02b2e393c70a227;hpb=8be9b358a544e1ea9e53ad40495fa42e9d5edf9a;p=unfold.git diff --git a/myslice/settings.py b/myslice/settings.py index 4df98e2e..17effaca 100644 --- a/myslice/settings.py +++ b/myslice/settings.py @@ -1,7 +1,14 @@ -# Django settings for myslice project. +# Django settings for unfold project. import os.path +### detect if we're in a build environment +try: + import manifold + building=False +except: + building=True + DEBUG = True TEMPLATE_DEBUG = DEBUG @@ -19,17 +26,39 @@ except: import traceback traceback.print_exc() -# find out DATAROOT, which is different from ROOT +#### this is where the problem lies I believe +# first try to run manage.py collectstatic without this +# themes +theme=None +try: + from myslice.configengine import ConfigEngine + configEngine = ConfigEngine() + if configEngine.myslice.theme : + theme = configEngine.myslice.theme +except: + pass + +# find out HTTPROOT, which is different from ROOT # when deployed from a package # this code is run by collectstatic too, so we cannot # assume we have ./static present already -DATAROOT="/usr/share/unfold" +HTTPROOT="/var/myslice-f4f" +# the place to store local data, like e.g. the sqlite db +DATAROOT="/var/unfold" # if not there, then we assume it's from a devel tree -if not os.path.isdir (os.path.join(DATAROOT,"static")): - DATAROOT=ROOT +if not os.path.isdir (os.path.join(HTTPROOT,"static")): + HTTPROOT=ROOT -if not os.path.isdir(ROOT): raise Exception,"Cannot find ROOT %s for myslice"%ROOT -if not os.path.isdir(DATAROOT): raise Exception,"Cannot find DATAROOT %s for myslice"%DATAROOT +if not os.path.isdir(ROOT): raise Exception,"Cannot find ROOT %s for unfold"%ROOT +if not os.path.isdir(HTTPROOT): raise Exception,"Cannot find HTTPROOT %s for unfold"%HTTPROOT + +# dec 2013 - we currently have 2 auxiliary subdirs with various utilities +# that we do not wish to package +# * sandbox is for plugin developers +# * sample is for various test views +# for each of these, if we find a directory of that name under ROOT, it then gets +# inserted in INSTALLED_APPS and its urls get included (see urls.py) +auxiliaries = [ 'sandbox', 'sample', ] #################### ADMINS = ( @@ -46,10 +75,22 @@ EMAIL_HOST = "localhost" EMAIL_PORT = 25 EMAIL_USE_TLS = False +# use the email for debugging purpose +# turn on debugging: +# python -m smtpd -n -c DebuggingServer localhost:1025 + +#if DEBUG: +# EMAIL_HOST = 'localhost' +# EMAIL_PORT = 1025 +# EMAIL_HOST_USER = '' +# EMAIL_HOST_PASSWORD = '' +# EMAIL_USE_TLS = False +# DEFAULT_FROM_EMAIL = 'testing@example.com' + DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'. - 'NAME': os.path.join(DATAROOT,'myslice.sqlite3'), # Or path to database file if using sqlite3. + 'NAME': os.path.join(DATAROOT,'unfold.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. @@ -61,7 +102,7 @@ DATABASES = { # http://en.wikipedia.org/wiki/List_of_tz_zones_by_name # although not all choices may be available on all operating systems. # In a Windows environment this must be set to your system time zone. -TIME_ZONE = 'America/Chicago' +TIME_ZONE = 'Europe/Paris' # Language code for this installation. All choices can be found here: # http://www.i18nguy.com/unicode/language-identifiers.html @@ -93,7 +134,7 @@ 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(DATAROOT,'static') +STATIC_ROOT = os.path.join(HTTPROOT,'static') # URL prefix for static files. # Example: "http://media.lawrence.com/static/" @@ -157,16 +198,18 @@ MIDDLEWARE_CLASSES = ( ROOT_URLCONF = 'myslice.urls' # Python dotted path to the WSGI application used by Django's runserver. -WSGI_APPLICATION = 'myslice.wsgi.application' - -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(DATAROOT,"templates"), -) - -INSTALLED_APPS = ( +WSGI_APPLICATION = 'unfold.wsgi.application' + +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. +if theme is not None: + TEMPLATE_DIRS.append ( os.path.join(HTTPROOT,"portal/templates", theme)) +TEMPLATE_DIRS.append ( os.path.join(HTTPROOT,"portal/templates")) +TEMPLATE_DIRS.append ( os.path.join(HTTPROOT,"templates")) + +INSTALLED_APPS = [ 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', @@ -179,7 +222,9 @@ INSTALLED_APPS = ( # our django project 'myslice', # the core of the UI - 'auth', 'manifold', 'unfold', + 'auth', + 'manifoldapi', + 'unfold', # plugins 'plugins', # views - more or less stable @@ -187,21 +232,20 @@ INSTALLED_APPS = ( # managing database migrations 'south', # Uncomment the next line to enable the admin: - # 'django.contrib.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', -) + # SLA + 'sla', +] +# this app won't load in a build environment +if not building: INSTALLED_APPS.append ('rest') + +for aux in auxiliaries: + if os.path.isdir(os.path.join(ROOT,aux)): + print "Using devel auxiliary",aux + INSTALLED_APPS.append(aux) ACCOUNT_ACTIVATION_DAYS = 7 # One-week activation window; you may, of course, use a different value. @@ -234,14 +278,24 @@ LOGGING = { } } -AUTHENTICATION_BACKENDS = ( 'auth.manifoldbackend.ManifoldBackend', ) +AUTHENTICATION_BACKENDS = ('auth.manifoldbackend.ManifoldBackend', + 'django.contrib.auth.backends.ModelBackend') ### 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' +CSRF_FAILURE_VIEW = 'manifoldapi.manifoldproxy.csrf_failure' #################### for insert_above #IA_JS_FORMAT = "