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

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

# We intentionally define lots of variables that aren't used, and
# want to import all variables from base settings files
13
# pylint: disable=wildcard-import, unused-wildcard-import
14

15
from .common import *
16

17
DEBUG = True
18
TEMPLATE_DEBUG = True
19

20
HTTPS = 'off'
21 22 23 24 25 26 27
FEATURES['DISABLE_START_DATES'] = False
FEATURES['ENABLE_SQL_TRACKING_LOGS'] = True
FEATURES['ENABLE_MANUAL_GIT_RELOAD'] = True
FEATURES['ENABLE_SERVICE_STATUS'] = True
FEATURES['ENABLE_SHOPPING_CART'] = True
FEATURES['AUTOMATIC_VERIFY_STUDENT_IDENTITY_FOR_TESTING'] = True
FEATURES['ENABLE_S3_GRADE_DOWNLOADS'] = True
28
FEATURES['ENABLE_PAYMENT_FAKE'] = True
29

30

31
FEEDBACK_SUBMISSION_EMAIL = "dummy@example.com"
32

33 34
WIKI_ENABLED = True

swdanielli committed
35 36 37 38 39
DJFS = {
    'type': 'osfs',
    'directory_root': 'lms/static/djpyfs',
    'url_root': '/static/djpyfs'
}
swdanielli committed
40

Julia Hansbrough committed
41 42
# If there is a database called 'read_replica', you can use the use_read_replica_if_available
# function in util/query.py, which is useful for very large database reads
43 44 45
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
46
        'NAME': ENV_ROOT / "db" / "edx.db",
47
        'ATOMIC_REQUESTS': True,
48 49 50 51 52
    },
    'student_module_history': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': ENV_ROOT / "db" / "student_module_history.db",
        'ATOMIC_REQUESTS': True,
53 54 55
    }
}

56
CACHES = {
57
    # This is the cache used for most things.
58 59 60
    # In staging/prod envs, the sessions also live here.
    'default': {
        'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
61
        'LOCATION': 'edx_loc_mem_cache',
62
        'KEY_FUNCTION': 'util.memcache.safe_key',
63 64 65 66 67 68 69 70 71 72 73
    },

    # 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,
74
        'KEY_FUNCTION': 'util.memcache.safe_key',
75 76 77 78 79 80 81
    },

    'mongo_metadata_inheritance': {
        'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache',
        'LOCATION': '/var/tmp/mongo_metadata_inheritance',
        'TIMEOUT': 300,
        'KEY_FUNCTION': 'util.memcache.safe_key',
82 83 84 85 86
    },
    'loc_cache': {
        'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
        'LOCATION': 'edx_location_mem_cache',
    },
87 88 89 90
    'course_structure_cache': {
        'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
        'LOCATION': 'edx_course_structure_mem_cache',
    },
91 92
}

93

94
XQUEUE_INTERFACE = {
kimth committed
95
    "url": "https://sandbox-xqueue.edx.org",
96
    "django_auth": {
97 98
        "username": "lms",
        "password": "***REMOVED***"
99 100
    },
    "basic_auth": ('anant', 'agarwal'),
101 102
}

103 104 105
# Make the keyedcache startup warnings go away
CACHE_TIMEOUT = 0

106 107
# Dummy secret key for dev
SECRET_KEY = '85920908f28904ed733fe576320db18cabd7b6cd'
108

109

110 111 112 113 114 115 116 117
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'],
118 119
    'berkeley': ['BerkeleyX/CS169/fa12',
                 'BerkeleyX/CS188/fa12'],
120
    'harvard': ['HarvardX/CS50x/2012H'],
121
    'mit': ['MITx/3.091/MIT_2012_Fall'],
122 123 124
    'sjsu': ['MITx/6.002x-EE98/2012_Fall_SJSU'],
}

125 126 127 128
# List of `university` landing pages to display, even though they may not
# have an actual course with that org set
VIRTUAL_UNIVERSITIES = []

129 130 131
# Organization that contain other organizations
META_UNIVERSITIES = {'UTx': ['UTAustinX']}

132 133
COMMENTS_SERVICE_KEY = "PUT_YOUR_API_KEY_HERE"

134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154
############################## 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'))
    ]


155
################################# edx-platform revision string  #####################
156

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

159
############################## LMS Migration ##################################
160
FEATURES['ENABLE_LMS_MIGRATION'] = True
161
FEATURES['XQA_SERVER'] = 'http://xqa:server@content-qa.edX.mit.edu/xqa'
162

163 164
INSTALLED_APPS += ('lms_migration',)

165
LMS_MIGRATION_ALLOWED_IPS = ['127.0.0.1']
166

ichuang committed
167
################################ OpenID Auth #################################
168

169 170 171
FEATURES['AUTH_USE_OPENID'] = True
FEATURES['AUTH_USE_OPENID_PROVIDER'] = True
FEATURES['BYPASS_ACTIVATION_EMAIL_FOR_EXTAUTH'] = True
ichuang committed
172 173 174

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

178
OPENID_PROVIDER_TRUSTED_ROOTS = ['*']
179

180 181 182
############################## OAUTH2 Provider ################################
FEATURES['ENABLE_OAUTH2_PROVIDER'] = True

183
######################## MIT Certificates SSL Auth ############################
184

185
FEATURES['AUTH_USE_CERTIFICATES'] = False
186

187 188 189 190
########################### External REST APIs #################################
FEATURES['ENABLE_MOBILE_REST_API'] = True
FEATURES['ENABLE_VIDEO_ABSTRACTION_LAYER_API'] = True

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

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

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

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

DEBUG_TOOLBAR_PANELS = (
206 207 208 209 210 211 212 213 214
    'debug_toolbar.panels.versions.VersionsPanel',
    'debug_toolbar.panels.timer.TimerPanel',
    'debug_toolbar.panels.settings.SettingsPanel',
    'debug_toolbar.panels.headers.HeadersPanel',
    'debug_toolbar.panels.request.RequestPanel',
    'debug_toolbar.panels.sql.SQLPanel',
    'debug_toolbar.panels.signals.SignalsPanel',
    'debug_toolbar.panels.logging.LoggingPanel',
    'debug_toolbar.panels.profiling.ProfilingPanel',
215 216
)

217
#################### FILE UPLOADS (for discussion forums) #####################
218

219 220
DEFAULT_FILE_STORAGE = 'django.core.files.storage.FileSystemStorage'
MEDIA_ROOT = ENV_ROOT / "uploads"
221 222
MEDIA_URL = "/static/uploads/"
STATICFILES_DIRS.append(("uploads", MEDIA_ROOT))
223 224 225 226
FILE_UPLOAD_TEMP_DIR = ENV_ROOT / "uploads"
FILE_UPLOAD_HANDLERS = (
    'django.core.files.uploadhandler.MemoryFileUploadHandler',
    'django.core.files.uploadhandler.TemporaryFileUploadHandler',
227
)
228

229 230
FEATURES['AUTH_USE_SHIB'] = True
FEATURES['RESTRICT_ENROLL_BY_REG_METHOD'] = True
231

232 233
########################### PIPELINE #################################

234
PIPELINE_SASS_ARGUMENTS = '--debug-info'
235

236 237
########################## ANALYTICS TESTING ########################

238
ANALYTICS_SERVER_URL = "http://127.0.0.1:9000/"
239
ANALYTICS_API_KEY = ""
240

241
##### Segment  ######
242

243
# If there's an environment variable set, grab it
244
LMS_SEGMENT_KEY = os.environ.get('SEGMENT_KEY')
245

246
###################### Payment ######################
247 248 249 250

CC_PROCESSOR['CyberSource']['SHARED_SECRET'] = os.environ.get('CYBERSOURCE_SHARED_SECRET', '')
CC_PROCESSOR['CyberSource']['MERCHANT_ID'] = os.environ.get('CYBERSOURCE_MERCHANT_ID', '')
CC_PROCESSOR['CyberSource']['SERIAL_NUMBER'] = os.environ.get('CYBERSOURCE_SERIAL_NUMBER', '')
251
CC_PROCESSOR['CyberSource']['PURCHASE_ENDPOINT'] = '/shoppingcart/payment_fake/'
252

253 254 255 256 257
CC_PROCESSOR['CyberSource2']['SECRET_KEY'] = os.environ.get('CYBERSOURCE_SECRET_KEY', '')
CC_PROCESSOR['CyberSource2']['ACCESS_KEY'] = os.environ.get('CYBERSOURCE_ACCESS_KEY', '')
CC_PROCESSOR['CyberSource2']['PROFILE_ID'] = os.environ.get('CYBERSOURCE_PROFILE_ID', '')
CC_PROCESSOR['CyberSource2']['PURCHASE_ENDPOINT'] = '/shoppingcart/payment_fake/'

258
########################## USER API ##########################
259
EDX_API_KEY = None
260

261
####################### Shoppingcart ###########################
262
FEATURES['ENABLE_SHOPPING_CART'] = True
263

264 265 266
### This enables the Metrics tab for the Instructor dashboard ###########
FEATURES['CLASS_DASHBOARD'] = True

267 268 269
### This settings is for the course registration code length ############
REGISTRATION_CODE_LENGTH = 8

270 271 272
#####################################################################
# Lastly, see if the developer has any local overrides.
try:
273
    from .private import *      # pylint: disable=import-error
274 275
except ImportError:
    pass