6 logger = logging.getLogger('myslice')
10 ROOT = os.path.realpath(os.path.dirname(__file__) + '/..')
13 logger.error(traceback.format_exc())
16 from myslice.configengine import ConfigEngine
18 config = ConfigEngine()
20 import myslice.components as components
23 # djcelery.setup_loader()
25 ### detect if we're in a build environment
32 if not config.myslice.portal_version:
34 PORTAL_VERSION = subprocess.check_output(["git", "describe"])
36 PORTAL_VERSION = 'not using git'
39 if config.myslice.debug :
41 INTERNAL_IPS = ("127.0.0.1","132.227.84.195","132.227.78.191","132.227.84.191")
46 if config.myslice.theme :
47 theme = config.myslice.theme
51 if config.myslice.theme_label :
52 theme_label = config.myslice.theme_label
56 if config.myslice.theme_logo :
57 theme_logo = config.myslice.theme_logo
59 theme_logo = theme + '.png'
62 if config.myslice.httproot :
63 HTTPROOT = config.myslice.httproot
68 if config.myslice.httproot :
69 DATAROOT = config.myslice.dataroot
74 # dec 2013 - we currently have 2 auxiliary subdirs with various utilities
75 # that we do not wish to package
76 # * sandbox is for plugin developers
77 # * sample is for various test views
78 # for each of these, if we find a directory of that name under ROOT, it then gets
79 # inserted in INSTALLED_APPS and its urls get included (see urls.py)
80 auxiliaries = [ 'sandbox', 'sample', ]
84 # ('your_name', 'your_email@test.com'),
90 #DEFAULT_FROM_EMAIL = "root@theseus.ipv6.lip6.fr"
91 #EMAIL_HOST_PASSWORD = "mypassword"
93 DEFAULT_FROM_EMAIL = "OneLab Support <support@onelab.eu>"
94 EMAIL_HOST = "localhost"
98 # use the email for debugging purpose
100 # python -m smtpd -n -c DebuggingServer localhost:1025
103 # EMAIL_HOST = 'localhost'
105 # EMAIL_HOST_USER = ''
106 # EMAIL_HOST_PASSWORD = ''
107 # EMAIL_USE_TLS = False
108 # DEFAULT_FROM_EMAIL = 'testing@example.com'
110 if config.database.engine :
113 'ENGINE' : 'django.db.backends.%s' % config.database.engine,
114 'USER' : config.database.user or '',
115 'PASSWORD' : config.database.password or '',
116 'HOST' : config.database.host or '',
117 'PORT' : config.database.port or '',
120 if config.database.engine == 'sqlite3' :
121 DATABASES['default']['NAME'] = os.path.join(DATAROOT,'%s.sqlite3' % config.database.name)
123 DATABASES['default']['NAME'] = config.database.name
125 # default database is sqlite
128 'ENGINE' : 'django.db.backends.sqlite3',
129 'NAME' : os.path.join(DATAROOT,'myslice.sqlite3'),
137 # Local time zone for this installation. Choices can be found here:
138 # http://en.wikipedia.org/wiki/List_of_tz_zones_by_name
139 # although not all choices may be available on all operating systems.
140 # In a Windows environment this must be set to your system time zone.
141 TIME_ZONE = 'Europe/Paris'
143 # Language code for this installation. All choices can be found here:
144 # http://www.i18nguy.com/unicode/language-identifiers.html
145 LANGUAGE_CODE = 'en-us'
149 # If you set this to False, Django will make some optimizations so as not
150 # to load the internationalization machinery.
153 # If you set this to False, Django will not format dates, numbers and
154 # calendars according to the current locale.
157 # If you set this to False, Django will not use timezone-aware datetimes.
160 # Absolute filesystem path to the directory that will hold user-uploaded files.
161 # Example: "/home/media/media.lawrence.com/media/"
164 # URL that handles the media served from MEDIA_ROOT. Make sure to use a
166 # Examples: "http://media.lawrence.com/media/", "http://example.com/media/"
169 # Absolute path to the directory static files should be collected to.
170 # Don't put anything in this directory yourself; store your static files
171 # in apps' "static/" subdirectories and in STATICFILES_DIRS.
172 # Example: "/home/media/media.lawrence.com/static/"
173 STATIC_ROOT = os.path.join(HTTPROOT,'static')
175 # Additional locations of static files
177 # Put strings here, like "/home/html/static" or "C:/www/django/static".
178 # Always use forward slashes, even on Windows.
179 # Don't forget to use absolute paths, not relative paths.
180 # Thierry : we do not need to detail the contents
181 # of our 'apps' since they're mentioned in INSTALLED_APPS
184 # Needed by PluginFinder
185 PLUGIN_DIR = os.path.join(ROOT,'plugins')
187 THIRDPARTY_DIR = os.path.join(ROOT, 'third-party')
189 # List of finder classes that know how to find static files in
191 STATICFILES_FINDERS = (
192 # Thierry : no need for this one
193 # 'django.contrib.staticfiles.finders.FileSystemFinder',
194 'django.contrib.staticfiles.finders.AppDirectoriesFinder',
195 'unfold.collectstatic.PluginFinder',
196 'unfold.collectstatic.ThirdPartyFinder',
197 ### 'django.contrib.staticfiles.finders.DefaultStorageFinder',
200 if config.myslice.secret_key:
201 # Make this unique, and don't share it with anybody.
202 SECRET_KEY = config.myslice.secret_key
204 raise Exception, "SECRET_KEY Not defined: Please setup a secret_key value in myslice.ini"
206 AUTHENTICATION_BACKENDS = ('localauth.manifoldbackend.ManifoldBackend',
207 'django.contrib.auth.backends.ModelBackend')
209 # List of callables that know how to import templates from various sources.
211 'django.template.loaders.filesystem.Loader',
212 'django.template.loaders.app_directories.Loader',
213 # 'django.template.loaders.eggs.Loader',
216 MIDDLEWARE_CLASSES = (
217 'django.middleware.common.CommonMiddleware',
218 'django.contrib.sessions.middleware.SessionMiddleware',
219 'django.middleware.csrf.CsrfViewMiddleware',
220 'django.contrib.auth.middleware.AuthenticationMiddleware',
221 'django.contrib.messages.middleware.MessageMiddleware',
222 # Uncomment the next line for simple clickjacking protection:
223 # 'django.middleware.clickjacking.XFrameOptionsMiddleware',
226 ROOT_URLCONF = 'myslice.urls'
228 # Python dotted path to the WSGI application used by Django's runserver.
229 WSGI_APPLICATION = 'unfold.wsgi.application'
232 # Put strings here, like "/home/html/django_templates" or "C:/www/django/templates".
233 # Always use forward slashes, even on Windows.
234 # Don't forget to use absolute paths, not relative paths.
235 if theme is not None:
236 TEMPLATE_DIRS.append( os.path.join(HTTPROOT,"portal/templates", theme) )
237 TEMPLATE_DIRS.append( os.path.join(HTTPROOT,"portal/templates") )
238 TEMPLATE_DIRS.append( os.path.join(HTTPROOT,"templates") )
241 'django.contrib.auth',
242 'django.contrib.contenttypes',
243 'django.contrib.sessions',
244 'django.contrib.sites',
245 'django.contrib.messages',
246 'django.contrib.staticfiles',
247 # handling the {% insert %} and {% container %} tags
248 # see details in devel/django-insert-above-1.0-4
258 # views - more or less stable
260 # Uncomment the next line to enable the admin:
261 'django.contrib.admin',
264 # Uncomment the next line to enable admin documentation:
265 # 'django.contrib.admindocs',
269 # with django-1.7 we leave south and use native migrations
270 # managing database migrations
272 major, minor, _, _, _ = django.VERSION
273 if major == 1 and minor <= 6:
274 INSTALLED_APPS.append('south')
276 # this app won't load in a build environment
278 INSTALLED_APPS.append ('rest')
280 for component in components.list() :
281 INSTALLED_APPS.append(component)
283 BROKER_URL = "amqp://myslice:myslice@localhost:5672/myslice"
285 for aux in auxiliaries:
286 if os.path.isdir(os.path.join(ROOT,aux)):
287 logger.info("Using devel auxiliary {}".format(aux))
288 INSTALLED_APPS.append(aux)
290 ACCOUNT_ACTIVATION_DAYS = 7 # One-week activation window; you may, of course, use a different value.
292 # A sample logging configuration. The only tangible logging
293 # performed by this configuration is to send an email to
294 # the site admins on every HTTP 500 error when DEBUG=False.
295 # See http://docs.djangoproject.com/en/dev/topics/logging for
296 # more details on how to customize your logging configuration.
299 'disable_existing_loggers': False,
301 'require_debug_false': {
302 '()': 'django.utils.log.RequireDebugFalse'
308 'filters': ['require_debug_false'],
309 'class': 'django.utils.log.AdminEmailHandler',
314 'handlers': ['mail_admins'],
322 'disable_existing_loggers': True,
325 'format': '%(levelname)s %(asctime)s %(module)s %(process)d %(thread)d %(message)s'
328 'format': '%(levelname)s %(message)s'
337 'class': 'django.utils.log.NullHandler',
341 'class': 'logging.StreamHandler',
342 'formatter': 'simple'
347 'handlers': ['debug'],
354 ### the view to redirect malformed (i.e. with a wrong CSRF) incoming requests
355 # without this setting django will return a 403 forbidden error, which is fine
356 # if you need to see the error message then use this setting
357 CSRF_FAILURE_VIEW = 'manifoldapi.manifoldproxy.csrf_failure'
359 #################### for insert_above
360 #IA_JS_FORMAT = "<script type='text/javascript' src='{URL}' />"
361 # put stuff under static/
362 # IA_MEDIA_PREFIX = '/code/'
366 SLA_COLLECTOR_URL = "http://157.193.215.125:4001/sla-collector/sla"
367 SLA_COLLECTOR_USER = "portal"
368 SLA_COLLECTOR_PASSWORD = "password"
371 # URL prefix for static files.
372 # Example: "http://media.lawrence.com/static/"
373 STATIC_URL = '/static/'