"""This is the standard development settings file. If you need to overload settings, please do so in a local_settings.py file (it won't be tracked in git). """ import os from urlparse import urlparse from olympia.lib.settings_base import * # noqa WSGI_APPLICATION = 'olympia.wsgi.application' DEBUG = True DEBUG_PROPAGATE_EXCEPTIONS = False # These apps are great during development. INSTALLED_APPS += ( 'olympia.landfill', ) # Using locmem deadlocks in certain scenarios. This should all be fixed, # hopefully, in Django1.7. At that point, we may try again, and remove this to # not require memcache installation for newcomers. # A failing scenario is: # 1/ log in # 2/ click on "Submit a new addon" # 3/ click on "I accept this Agreement" => request never ends # # If this is changed back to locmem, make sure to use it from "caching" (by # default in Django for locmem, a timeout of "0" means "don't cache it", while # on other backends it means "cache forever"): # 'BACKEND': 'caching.backends.locmem.LocMemCache' CACHES = { 'default': { 'BACKEND': 'caching.backends.memcached.MemcachedCache', 'LOCATION': os.environ.get('MEMCACHE_LOCATION', 'localhost:11211'), } } # For local development, we don't need syslog and mozlog loggers. USE_SYSLOG = False USE_MOZLOG = False # If you're not running on SSL you'll want this to be False. SESSION_COOKIE_SECURE = False SESSION_COOKIE_DOMAIN = None CELERY_TASK_ALWAYS_EAGER = False # If you want to allow self-reviews for add-ons/apps, then enable this. # In production we do not want to allow this. ALLOW_SELF_REVIEWS = True # Assuming you did `npm install` (and not `-g`) like you were supposed to, this # will be the path to the `stylus` and `lessc` executables. STYLUS_BIN = os.getenv('STYLUS_BIN', path('node_modules/stylus/bin/stylus')) LESS_BIN = os.getenv('LESS_BIN', path('node_modules/less/bin/lessc')) CLEANCSS_BIN = os.getenv( 'CLEANCSS_BIN', path('node_modules/clean-css-cli/bin/cleancss')) UGLIFY_BIN = os.getenv( 'UGLIFY_BIN', path('node_modules/uglify-js/bin/uglifyjs')) ADDONS_LINTER_BIN = os.getenv( 'ADDONS_LINTER_BIN', path('node_modules/addons-linter/bin/addons-linter')) # Locally we typically don't run more than 1 elasticsearch node. So we set # replicas to zero. ES_DEFAULT_NUM_REPLICAS = 0 SITE_URL = os.environ.get('OLYMPIA_SITE_URL') or 'http://localhost:8000' SERVICES_DOMAIN = urlparse(SITE_URL).netloc SERVICES_URL = SITE_URL ALLOWED_HOSTS = ALLOWED_HOSTS + [SERVICES_DOMAIN] ADDON_COLLECTOR_ID = 1 # Default AMO user id to use for tasks (from users.json fixture in zadmin). TASK_USER_ID = 10968 # Set to True if we're allowed to use X-SENDFILE. XSENDFILE = False AES_KEYS = { 'api_key:secret': os.path.join( ROOT, 'src', 'olympia', 'api', 'tests', 'assets', 'test-api-key.txt'), } # FxA config for local development only. FXA_CONFIG = { 'default': { 'client_id': 'cd5a21fafacc4744', 'client_secret': '4db6f78940c6653d5b0d2adced8caf6c6fd8fd4f2a3a448da927a54daba7d401', 'content_host': 'https://stable.dev.lcip.org', 'oauth_host': 'https://oauth-stable.dev.lcip.org/v1', 'profile_host': 'https://stable.dev.lcip.org/profile/v1', 'redirect_url': 'http://olympia.dev/api/v3/accounts/authenticate/', 'scope': 'profile', }, 'internal': { 'client_id': '0f95f6474c24c1dc', 'client_secret': 'ca45e503a1b4ec9e2a3d4855d79849e098da18b7dfe42b6bc76dfed420fc1d38', 'content_host': 'https://stable.dev.lcip.org', 'oauth_host': 'https://oauth-stable.dev.lcip.org/v1', 'profile_host': 'https://stable.dev.lcip.org/profile/v1', 'redirect_url': 'http://localhost:3000/fxa-authenticate', 'scope': 'profile', 'skip_register_redirect': True, }, 'local': { 'client_id': '1778aef72d1adfb3', 'client_secret': '3feebe3c009c1a0acdedd009f3530eae2b88859f430fa8bb951ea41f2f859b18', 'content_host': 'https://stable.dev.lcip.org', 'oauth_host': 'https://oauth-stable.dev.lcip.org/v1', 'profile_host': 'https://stable.dev.lcip.org/profile/v1', 'redirect_url': 'http://localhost:3000/api/v3/accounts/authenticate/', 'scope': 'profile', }, } FXA_CONFIG['amo'] = FXA_CONFIG['internal'] ALLOWED_FXA_CONFIGS = ['default', 'amo', 'local'] # CSP report endpoint which returns a 204 from addons-nginx in local dev. CSP_REPORT_URI = '/csp-report' # Allow GA over http + www subdomain in local development. HTTP_GA_SRC = 'http://www.google-analytics.com' CSP_FRAME_SRC += ('https://www.sandbox.paypal.com',) CSP_IMG_SRC += (HTTP_GA_SRC,) CSP_SCRIPT_SRC += (HTTP_GA_SRC, "'self'") # Auth token required to authorize inbound email. INBOUND_EMAIL_SECRET_KEY = 'totally-unsecure-secret-string' # Validation key we need to send in POST response. INBOUND_EMAIL_VALIDATION_KEY = 'totally-unsecure-validation-string' # For the Github webhook API. GITHUB_API_USER = '' GITHUB_API_TOKEN = '' # If you have settings you want to overload, put them in a local_settings.py. try: from local_settings import * # noqa except ImportError: pass