7b9e3c2731858d2f6ccecda4cc31607e780772dd
[myslice.git] / myslice / settings.py
1 # Django settings for myslice project.
2
3 import os.path
4
5 DEBUG = True
6 TEMPLATE_DEBUG = DEBUG
7
8 # compute ROOT from where this file is installed
9 # should fit every need including developers
10 # but you can redefine ROOT if that's not working for you
11 try:
12     # get the directory where this file is
13     ROOT=os.path.dirname(__file__) or '.'
14     # move one step up
15     ROOT=os.path.realpath(ROOT+'/..')
16 except:
17     ROOT=None
18     if DEBUG:
19         import traceback
20         traceback.print_exc()
21
22 if not ROOT:
23     raise Exception,"Cannot find ROOT for myslice"
24
25 ####################
26 ADMINS = (
27     # ('your_name', 'your_email@test.com'),
28 )
29
30 MANAGERS = ADMINS
31
32 # Mail configuration
33 #DEFAULT_FROM_EMAIL = "root@theseus.ipv6.lip6.fr"
34 #EMAIL_HOST_PASSWORD = "mypassword"
35
36 EMAIL_HOST = "localhost"
37 EMAIL_PORT = 25
38 EMAIL_USE_TLS = False
39
40 DATABASES = {
41     'default': {
42         'ENGINE': 'django.db.backends.sqlite3', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'.
43         'NAME': os.path.join(ROOT,'myslice.sqlite3'), # Or path to database file if using sqlite3.
44         'USER': '',                      # Not used with sqlite3.
45         'PASSWORD': '',                  # Not used with sqlite3.
46         'HOST': '',                      # Set to empty string for localhost. Not used with sqlite3.
47         'PORT': '',                      # Set to empty string for default. Not used with sqlite3.
48     }
49 }
50
51 # Local time zone for this installation. Choices can be found here:
52 # http://en.wikipedia.org/wiki/List_of_tz_zones_by_name
53 # although not all choices may be available on all operating systems.
54 # In a Windows environment this must be set to your system time zone.
55 TIME_ZONE = 'America/Chicago'
56
57 # Language code for this installation. All choices can be found here:
58 # http://www.i18nguy.com/unicode/language-identifiers.html
59 LANGUAGE_CODE = 'en-us'
60
61 SITE_ID = 1
62
63 # If you set this to False, Django will make some optimizations so as not
64 # to load the internationalization machinery.
65 USE_I18N = True
66
67 # If you set this to False, Django will not format dates, numbers and
68 # calendars according to the current locale.
69 USE_L10N = True
70
71 # If you set this to False, Django will not use timezone-aware datetimes.
72 USE_TZ = True
73
74 # Absolute filesystem path to the directory that will hold user-uploaded files.
75 # Example: "/home/media/media.lawrence.com/media/"
76 MEDIA_ROOT = ''
77
78 # URL that handles the media served from MEDIA_ROOT. Make sure to use a
79 # trailing slash.
80 # Examples: "http://media.lawrence.com/media/", "http://example.com/media/"
81 MEDIA_URL = ''
82
83 # Absolute path to the directory static files should be collected to.
84 # Don't put anything in this directory yourself; store your static files
85 # in apps' "static/" subdirectories and in STATICFILES_DIRS.
86 # Example: "/home/media/media.lawrence.com/static/"
87 STATIC_ROOT = os.path.join(ROOT,'static')
88
89 # URL prefix for static files.
90 # Example: "http://media.lawrence.com/static/"
91 STATIC_URL = '/static/'
92
93 # Additional locations of static files
94 STATICFILES_DIRS = (
95     # Put strings here, like "/home/html/static" or "C:/www/django/static".
96     # Always use forward slashes, even on Windows.
97     # Don't forget to use absolute paths, not relative paths.
98     # Thierry : we do not need to detail the contents 
99     # of our 'apps' since they're mentioned in INSTALLED_APPS
100 )
101
102 # Needed by PluginFinder
103 PLUGIN_DIR = os.path.join(ROOT,'plugins')
104 # ThirdPartyFinder
105 THIRDPARTY_DIR = os.path.join(ROOT, 'third-party')
106
107 # List of finder classes that know how to find static files in
108 # various locations.
109 STATICFILES_FINDERS = (
110 # Thierry : no need for this one    
111 #    'django.contrib.staticfiles.finders.FileSystemFinder',
112     'django.contrib.staticfiles.finders.AppDirectoriesFinder',
113     'unfold.collectstatic.PluginFinder',
114     'unfold.collectstatic.ThirdPartyFinder',
115 ###    'django.contrib.staticfiles.finders.DefaultStorageFinder',
116 )
117
118 #TEMPLATE_CONTEXT_PROCESSORS = (
119 #    'django.contrib.auth.context_processors.auth',
120 #    'django.core.context_processors.debug',
121 #    'django.core.context_processors.i18n',
122 #    'django.core.context_processors.media',
123 #    'django.core.context_processors.static',
124 #    'django.core.context_processors.request',
125 #    'django.contrib.messages.context_processors.messages',
126 #)
127
128 # Make this unique, and don't share it with anybody.
129 SECRET_KEY = 't%n(3h)&r^n8(+8)(sp29t^$c2#t(m3)e2!02l8w1#36tl#t27'
130
131 # List of callables that know how to import templates from various sources.
132 TEMPLATE_LOADERS = (
133     'django.template.loaders.filesystem.Loader',
134     'django.template.loaders.app_directories.Loader',
135 #     'django.template.loaders.eggs.Loader',
136 )
137
138 MIDDLEWARE_CLASSES = (
139     'django.middleware.common.CommonMiddleware',
140     'django.contrib.sessions.middleware.SessionMiddleware',
141     'django.middleware.csrf.CsrfViewMiddleware',
142     'django.contrib.auth.middleware.AuthenticationMiddleware',
143     'django.contrib.messages.middleware.MessageMiddleware',
144     # Uncomment the next line for simple clickjacking protection:
145     # 'django.middleware.clickjacking.XFrameOptionsMiddleware',
146 )
147
148 ROOT_URLCONF = 'myslice.urls'
149
150 # Python dotted path to the WSGI application used by Django's runserver.
151 WSGI_APPLICATION = 'apache.wsgi.application'
152
153 TEMPLATE_DIRS = (
154     # Put strings here, like "/home/html/django_templates" or "C:/www/django/templates".
155     # Always use forward slashes, even on Windows.
156     # Don't forget to use absolute paths, not relative paths.
157     os.path.join(ROOT,"templates"),
158 )
159
160 INSTALLED_APPS = (
161     'django.contrib.auth',
162     'django.contrib.contenttypes',
163     'django.contrib.sessions',
164     'django.contrib.sites',
165     'django.contrib.messages',
166     'django.contrib.staticfiles',
167     # handling the {% insert %} and {% container %} tags
168     # see details in devel/django-insert-above-1.0-4
169     'insert_above',
170     # our django project
171     'myslice',
172     # the core of the UI
173     'auth', 'manifold', 'unfold',
174     # plugins
175     'plugins',
176     # views - more or less stable 
177     'ui',
178     # managing database migrations
179     'south', 
180     # Uncomment the next line to enable the admin:
181     # 'django.contrib.admin',
182     # Uncomment the next line to enable admin documentation:
183     # 'django.contrib.admindocs',
184     'portal',
185     # temporary - not packaged
186     'trash',
187     'sample',
188 # DEPRECATED #    'django.contrib.formtools',
189 # DEPRECATED ##    'crispy_forms',
190 # DEPRECATED #
191 # DEPRECATED #    # User registration
192 # DEPRECATED #    'django.contrib.auth',
193 # DEPRECATED #    'django.contrib.sites',
194 # DEPRECATED #    'registration',
195 )
196
197 ACCOUNT_ACTIVATION_DAYS = 7 # One-week activation window; you may, of course, use a different value.
198
199 # A sample logging configuration. The only tangible logging
200 # performed by this configuration is to send an email to
201 # the site admins on every HTTP 500 error when DEBUG=False.
202 # See http://docs.djangoproject.com/en/dev/topics/logging for
203 # more details on how to customize your logging configuration.
204 LOGGING = {
205     'version': 1,
206     'disable_existing_loggers': False,
207     'filters': {
208         'require_debug_false': {
209             '()': 'django.utils.log.RequireDebugFalse'
210         }
211     },
212     'handlers': {
213         'mail_admins': {
214             'level': 'ERROR',
215             'filters': ['require_debug_false'],
216             'class': 'django.utils.log.AdminEmailHandler',
217         }
218     },
219     'loggers': {
220         'django.request': {
221             'handlers': ['mail_admins'],
222             'level': 'ERROR',
223             'propagate': True,
224         },
225     }
226 }
227
228 AUTHENTICATION_BACKENDS = ( 'auth.manifoldbackend.ManifoldBackend', )
229
230 ### the view to redirect malformed (i.e. with a wrong CSRF) incoming requests
231 # without this setting django will return a 403 forbidden error, which is fine
232 # if you need to see the error message then use this setting
233 CSRF_FAILURE_VIEW = 'manifold.manifoldproxy.csrf_failure'
234
235 #################### for insert_above
236 #IA_JS_FORMAT = "<script type='text/javascript' src='{URL}' />"
237 # put stuff under static/
238 # IA_MEDIA_PREFIX = '/code/'