dev.py 8.69 KB
Newer Older
1 2
"""
This config file runs the simplest dev environment using sqlite, and db-based
3 4 5 6 7
sessions. Assumes structure:

/envroot/
        /db   # This is where it'll write the database file
        /mitx # The location of this repo
8
        /log  # Where we're going to write log files
9
"""
10 11 12 13 14

# We intentionally define lots of variables that aren't used, and
# want to import all variables from base settings files
# pylint: disable=W0401, W0614

15
from .common import *
16
from logsettings import get_logger_config
17

18
DEBUG = True
19
TEMPLATE_DEBUG = True
20

21

22
MITX_FEATURES['DISABLE_START_DATES'] = True
23
MITX_FEATURES['ENABLE_SQL_TRACKING_LOGS'] = True
24
MITX_FEATURES['SUBDOMAIN_COURSE_LISTINGS'] = False  # Enable to test subdomains--otherwise, want all courses to show up
25
MITX_FEATURES['SUBDOMAIN_BRANDING'] = True
26
MITX_FEATURES['FORCE_UNIVERSITY_DOMAIN'] = None		# show all university courses if in dev (ie don't use HTTP_HOST)
27
MITX_FEATURES['ENABLE_MANUAL_GIT_RELOAD'] = True
28
MITX_FEATURES['ENABLE_PSYCHOMETRICS'] = False    # real-time psychometrics (eg item response theory analysis in instructor dashboard)
29
MITX_FEATURES['ENABLE_INSTRUCTOR_ANALYTICS'] = True
30
MITX_FEATURES['ENABLE_SERVICE_STATUS'] = True
31

32 33
WIKI_ENABLED = True

34
LOGGING = get_logger_config(ENV_ROOT / "log",
35
                            logging_env="dev",
36 37
                            local_loglevel="DEBUG",
                            dev_env=True,
38
                            debug=True)
39

40 41 42 43 44 45 46
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': ENV_ROOT / "db" / "mitx.db",
    }
}

47
CACHES = {
48
    # This is the cache used for most things.
49 50 51
    # In staging/prod envs, the sessions also live here.
    'default': {
        'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
52 53
        'LOCATION': 'mitx_loc_mem_cache',
        'KEY_FUNCTION': 'util.memcache.safe_key',
54 55 56 57 58 59 60 61 62 63 64
    },

    # The general cache is what you get if you use our util.cache. It's used for
    # things like caching the course.xml file for different A/B test groups.
    # We set it to be a DummyCache to force reloading of course.xml in dev.
    # In staging environments, we would grab VERSION from data uploaded by the
    # push process.
    'general': {
        'BACKEND': 'django.core.cache.backends.dummy.DummyCache',
        'KEY_PREFIX': 'general',
        'VERSION': 4,
65
        'KEY_FUNCTION': 'util.memcache.safe_key',
66 67 68 69 70 71 72
    },

    'mongo_metadata_inheritance': {
        'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache',
        'LOCATION': '/var/tmp/mongo_metadata_inheritance',
        'TIMEOUT': 300,
        'KEY_FUNCTION': 'util.memcache.safe_key',
73 74 75
    }
}

76

77
XQUEUE_INTERFACE = {
kimth committed
78
    "url": "https://sandbox-xqueue.edx.org",
79
    "django_auth": {
80 81
        "username": "lms",
        "password": "***REMOVED***"
82 83
    },
    "basic_auth": ('anant', 'agarwal'),
84 85
}

86 87 88
# Make the keyedcache startup warnings go away
CACHE_TIMEOUT = 0

89 90
# Dummy secret key for dev
SECRET_KEY = '85920908f28904ed733fe576320db18cabd7b6cd'
91

92

93 94 95 96 97 98 99 100
COURSE_LISTINGS = {
    'default': ['BerkeleyX/CS169.1x/2012_Fall',
                'BerkeleyX/CS188.1x/2012_Fall',
                'HarvardX/CS50x/2012',
                'HarvardX/PH207x/2012_Fall',
                'MITx/3.091x/2012_Fall',
                'MITx/6.002x/2012_Fall',
                'MITx/6.00x/2012_Fall'],
101 102
    'berkeley': ['BerkeleyX/CS169/fa12',
                 'BerkeleyX/CS188/fa12'],
103
    'harvard': ['HarvardX/CS50x/2012H'],
104
    'mit': ['MITx/3.091/MIT_2012_Fall'],
105 106 107
    'sjsu': ['MITx/6.002x-EE98/2012_Fall_SJSU'],
}

108

109 110 111 112 113 114 115
SUBDOMAIN_BRANDING = {
    'sjsu': 'MITx',
    'mit': 'MITx',
    'berkeley': 'BerkeleyX',
    'harvard': 'HarvardX',
}

116 117 118 119
# List of `university` landing pages to display, even though they may not
# have an actual course with that org set
VIRTUAL_UNIVERSITIES = []

120 121 122
# Organization that contain other organizations
META_UNIVERSITIES = {'UTx': ['UTAustinX']}

123 124
COMMENTS_SERVICE_KEY = "PUT_YOUR_API_KEY_HERE"

125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145
############################## Course static files ##########################
if os.path.isdir(DATA_DIR):
    # Add the full course repo if there is no static directory
    STATICFILES_DIRS += [
        # TODO (cpennington): When courses are stored in a database, this
        # should no longer be added to STATICFILES
        (course_dir, DATA_DIR / course_dir)
        for course_dir in os.listdir(DATA_DIR)
        if (os.path.isdir(DATA_DIR / course_dir) and
            not os.path.isdir(DATA_DIR / course_dir / 'static'))
    ]
    # Otherwise, add only the static directory from the course dir
    STATICFILES_DIRS += [
        # TODO (cpennington): When courses are stored in a database, this
        # should no longer be added to STATICFILES
        (course_dir, DATA_DIR / course_dir / 'static')
        for course_dir in os.listdir(DATA_DIR)
        if (os.path.isdir(DATA_DIR / course_dir / 'static'))
    ]


146 147 148 149
################################# mitx revision string  #####################

MITX_VERSION_STRING = os.popen('cd %s; git describe' % REPO_ROOT).read().strip()

150
############################ Open ended grading config  #####################
Vik Paruchuri committed
151 152 153 154 155 156 157 158 159

OPEN_ENDED_GRADING_INTERFACE = {
    'url' : 'http://127.0.0.1:3033/',
    'username' : 'lms',
    'password' : 'abcd',
    'staff_grading' : 'staff_grading',
    'peer_grading' : 'peer_grading',
    'grading_controller' : 'grading_controller'
}
160

161
############################## LMS Migration ##################################
162
MITX_FEATURES['ENABLE_LMS_MIGRATION'] = True
163
MITX_FEATURES['ACCESS_REQUIRE_STAFF_FOR_COURSE'] = False   # require that user be in the staff_* group to be able to enroll
164
MITX_FEATURES['USE_XQA_SERVER'] = 'http://xqa:server@content-qa.mitx.mit.edu/xqa'
165

166 167
INSTALLED_APPS += ('lms_migration',)

168
LMS_MIGRATION_ALLOWED_IPS = ['127.0.0.1']
169

ichuang committed
170
################################ OpenID Auth #################################
171

ichuang committed
172
MITX_FEATURES['AUTH_USE_OPENID'] = True
173
MITX_FEATURES['AUTH_USE_OPENID_PROVIDER'] = True
ichuang committed
174
MITX_FEATURES['BYPASS_ACTIVATION_EMAIL_FOR_EXTAUTH'] = True
ichuang committed
175

176
INSTALLED_APPS += ('external_auth',)
ichuang committed
177 178 179 180
INSTALLED_APPS += ('django_openid_auth',)

OPENID_CREATE_USERS = False
OPENID_UPDATE_DETAILS_FROM_SREG = True
181
OPENID_SSO_SERVER_URL = 'https://www.google.com/accounts/o8/id'  # TODO: accept more endpoints
ichuang committed
182 183
OPENID_USE_AS_ADMIN_LOGIN = False

184
OPENID_PROVIDER_TRUSTED_ROOTS = ['*']
185

186
######################## MIT Certificates SSL Auth ############################
187

188 189
MITX_FEATURES['AUTH_USE_MIT_CERTIFICATES'] = True

190 191 192 193 194 195 196
################################# CELERY ######################################

# By default don't use a worker, execute tasks as if they were local functions
CELERY_ALWAYS_EAGER = True

################################ DEBUG TOOLBAR ################################

197
INSTALLED_APPS += ('debug_toolbar',)
198 199
MIDDLEWARE_CLASSES += ('django_comment_client.utils.QueryCountDebugMiddleware',
                       'debug_toolbar.middleware.DebugToolbarMiddleware',)
200
INTERNAL_IPS = ('127.0.0.1',)
201 202 203 204

DEBUG_TOOLBAR_PANELS = (
   'debug_toolbar.panels.version.VersionDebugPanel',
   'debug_toolbar.panels.timer.TimerDebugPanel',
205
   'debug_toolbar.panels.settings_vars.SettingsVarsDebugPanel',
206 207 208 209 210
   'debug_toolbar.panels.headers.HeaderDebugPanel',
   'debug_toolbar.panels.request_vars.RequestVarsDebugPanel',
   'debug_toolbar.panels.sql.SQLDebugPanel',
   'debug_toolbar.panels.signals.SignalDebugPanel',
   'debug_toolbar.panels.logger.LoggingPanel',
211 212

#  Enabling the profiler has a weird bug as of django-debug-toolbar==0.9.4 and
213 214
#  Django=1.3.1/1.4 where requests to views get duplicated (your method gets
#  hit twice). So you can uncomment when you need to diagnose performance
215 216
#  problems, but you shouldn't leave it on.
#  'debug_toolbar.panels.profiling.ProfilingDebugPanel',
217 218
)

219 220 221
DEBUG_TOOLBAR_CONFIG = {
    'INTERCEPT_REDIRECTS': False
}
222

223
#################### FILE UPLOADS (for discussion forums) #####################
224

225 226
DEFAULT_FILE_STORAGE = 'django.core.files.storage.FileSystemStorage'
MEDIA_ROOT = ENV_ROOT / "uploads"
227 228
MEDIA_URL = "/static/uploads/"
STATICFILES_DIRS.append(("uploads", MEDIA_ROOT))
229 230 231 232
FILE_UPLOAD_TEMP_DIR = ENV_ROOT / "uploads"
FILE_UPLOAD_HANDLERS = (
    'django.core.files.uploadhandler.MemoryFileUploadHandler',
    'django.core.files.uploadhandler.TemporaryFileUploadHandler',
233
)
234 235 236

########################### PIPELINE #################################

237
PIPELINE_SASS_ARGUMENTS = '--debug-info --require {proj_dir}/static/sass/bourbon/lib/bourbon.rb'.format(proj_dir=PROJECT_ROOT)
238 239

########################## PEARSON TESTING ###########################
240
MITX_FEATURES['ENABLE_PEARSON_LOGIN'] = False
241 242 243

########################## ANALYTICS TESTING ########################

244
ANALYTICS_SERVER_URL = "http://127.0.0.1:9000/"
245
ANALYTICS_API_KEY = ""
246 247 248 249 250 251 252 253


#####################################################################
# Lastly, see if the developer has any local overrides.
try:
    from .private import *
except ImportError:
    pass