Skip to content
Snippets Groups Projects
default.py 13.6 KiB
Newer Older
from utils import posixToGpsTime
from datetime import datetime, timedelta
import time
import logging
from cloghandler import ConcurrentRotatingFileHandler

from settings_secret import *

Brian Moe's avatar
Brian Moe committed

Brian Moe's avatar
Brian Moe committed
# Suitable for production
Brian Moe's avatar
Brian Moe committed
DEBUG = False
MAINTENANCE_MODE = False
Brian Moe's avatar
Brian Moe committed
ADMINS = (
    ('Alexander Pace', 'aep14@psu.edu'),
    ('Tanner Prestegard', 'tanner.prestegard@ligo.org'),
Brian Moe's avatar
Brian Moe committed
)
MANAGERS = ADMINS
Brian Moe's avatar
Brian Moe committed

TWIML_BASE_URL = 'https://handler.twilio.com/twiml/'

# Email settings.
#EMAIL_HOST = 'gravity.phys.uwm.edu'
EMAIL_HOST = 'localhost'
SERVER_EMAIL = 'GraceDB <gracedb@gracedb.cgca.uwm.edu>'
ALERT_EMAIL_TO = []
ALERT_EMAIL_BCC = []
ALERT_TEST_EMAIL_FROM = "GraceDB TESTING <gracedb@gracedb.cgca.uwm.edu>"
ALERT_TEST_EMAIL_TO = []
# LVAlert and LVAlert Overseer settings
LVALERT_SEND_EXECUTABLE = '/home/gracedb/djangoenv/bin/lvalert_send'
ALERT_XMPP_SERVERS = ["lvalert.cgca.uwm.edu"]
USE_LVALERT_OVERSEER = True
# For each lvalert server, a separate instance of the lvalert_overseer
# must be running and listening on a distinct port. 
LVALERT_OVERSEER_PORTS = {
    'lvalert.cgca.uwm.edu': 8000,
}

EMBB_MAIL_ADDRESS = 'embb@gracedb.ligo.org'
EMBB_SMTP_SERVER = 'localhost'
EMBB_MAIL_ADMINS = ['branson@gravity.phys.uwm.edu','roy.williams@ligo.org',]
EMBB_IGNORE_ADDRESSES = ['Mailer-Daemon@gracedb.cgca.uwm.edu',]
# Added for django 1.7.8
TEST_RUNNER = 'django.test.runner.DiscoverRunner'

# Some proper names related to authorization
LVC_GROUP = 'Communities:LSCVirgoLIGOGroupMembers'
LVEM_GROUP = 'gw-astronomy:LV-EM'
LVEM_OBSERVERS_GROUP = 'gw-astronomy:LV-EM:Observers'
# Groups directly managed by GraceDB admins
ADMIN_MANAGED_GROUPS = [EM_ADVOCATE_GROUP, 'executives',]

EXTERNAL_ACCESS_TAGNAME = 'lvem'

# FAR floor for outgoing VOEvents intended for GCN
#VOEVENT_FAR_FLOOR = 3.17e-10 # 1/100 yrs
VOEVENT_FAR_FLOOR = 0

# URL for viewing skymaps
SKYMAP_VIEWER_SERVICE_URL = \
    "https://embb-dev.ligo.caltech.edu/skymap-viewer/aladin/skymap-viewer.cgi"
# Log entries with these tags are displayed in
# their own blocks in the web interface.
                 'analyst_comments',
                 'data_quality',
DATABASES = {
    'default' : {
        'NAME'     : 'gracedb',
        'ENGINE'   : 'django.db.backends.mysql',
        'USER'     : 'gracedb',
        'PASSWORD' : DEFAULT_DB_PASSWORD,
                         'init_command': 'SET storage_engine=MyISAM',
CACHES = {
    'default': {
        'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
        'LOCATION': '127.0.0.1:11211',
    }
}

SKYALERT_IVORN_PATTERN = "ivo://gwnet/gcn_sender#%s"
SKYALERT_DESCRIPTION   = "Report of a candidate gravitational wave event"
SKYALERT_SUBMITTERS = ['Patrick Brady', 'Brian Moe']

# Location of database
GRACEDB_DATA_DIR = "/opt/gracedb/data"
# First level subdirs with 2 chars, second level with 1 char
# These DIR_DIGITS had better add up to a number less than 40 (which is
# the length of a SHA-1 hexdigest. Actually, it should be way less than
# 40--or you're a crazy person.
GRACEDB_DIR_DIGITS = [2, 1,]
# Latency histograms.  Where they go and max latency to bin.
LATENCY_REPORT_DEST_DIR = "/home/gracedb/data/latency"
LATENCY_MAXIMUM_CHARTED = 1800
LATENCY_REPORT_WEB_PAGE_FILE_PATH = LATENCY_REPORT_DEST_DIR + "/latency.inc"

Brian Moe's avatar
Brian Moe committed
# Uptime reporting
UPTIME_REPORT_DIR = "/home/gracedb/data/uptime"
Brian Moe's avatar
Brian Moe committed

# Rate file location
RATE_INFO_FILE = "/home/gracedb/data/rate_info.json"

# URL prefix for serving report information (usually plots and tables)
REPORT_INFO_URL_PREFIX = "/report_info/"
Brian Moe's avatar
Brian Moe committed

Brian Moe's avatar
Brian Moe committed
# Find another way to do this.
#
# CBC IFAR Reports

now = datetime.now()
yesterday = now - timedelta(days=1)
lastweek = now - timedelta(days=7)
now = posixToGpsTime(time.mktime(now.timetuple()))
yesterday = posixToGpsTime(time.mktime(yesterday.timetuple()))
lastweek = posixToGpsTime(time.mktime(lastweek.timetuple()))

REPORT_IFAR_IMAGE_DIR = LATENCY_REPORT_DEST_DIR
#REPORTS_IFAR = [
#    #(query, axis_label, title, fname),
#    ("LowMass %d..%d" % (yesterday, now),
#     "GraceDB CBC LowMass ER1 events",
#     "ER1 FARs from gstlal_ll_inspiral - last day",
#     "ifar_day.png"
#    ),
#    ("LowMass %d..%d" % (lastweek, now),
#     "GraceDB CBC LowMass ER1 events",
#     "ER1 FARs from gstlal_ll_inspiral - last week",
#     "ifar_week.png"
#    ),
#]
REPORTS_IFAR = [
    #(query, axis_label, title, fname),
    ("gstlal %d..%d" % (yesterday, now),
     "GraceDB gstlal events",
     "FARs from gstlal - last day",
     "ifar_day.png"
    ),
    ("gstlal %d..%d" % (lastweek, now),
     "GraceDB gstlal events",
     "FARs from gstlal - last week",
     "ifar_week.png"
    ),
]
Brian Moe's avatar
Brian Moe committed

BINNED_COUNT_PIPELINES = ['gstlal', 'MBTAOnline', 'CWB', 'LIB', 'gstlal-spiir']
BINNED_COUNT_FILE = "/home/gracedb/data/binned_counts.json"

# Whether or not to show the recent events on the landing page
SHOW_RECENT_EVENTS_ON_HOME = False
FEED_MAX_RESULTS = 50
Brian Moe's avatar
Brian Moe committed
# Local time zone for this installation. Choices can be found here:
# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name
# although not all choices may be available on all operating systems.
# If running in a Windows environment this must be set to the same as your
# system time zone.
TIME_ZONE = 'America/Chicago'
Brian Moe's avatar
Brian Moe committed
GRACE_DATETIME_FORMAT = 'Y-m-d H:i:s T'
Brian Moe's avatar
Brian Moe committed

# Language code for this installation. All choices can be found here:
# http://www.i18nguy.com/unicode/language-identifiers.html
LANGUAGE_CODE = 'en-us'

# If you set this to False, Django will make some optimizations so as not
# to load the internationalization machinery.
Brian Moe's avatar
Brian Moe committed
USE_I18N = False
Brian Moe's avatar
Brian Moe committed

# Absolute path to the directory that holds media.
# Example: "/home/media/media.lawrence.com/"
Brian Moe's avatar
Brian Moe committed

# URL that handles the media served from MEDIA_ROOT. Make sure to use a
# trailing slash if there is a path component (optional in other cases).
# Examples: "http://media.lawrence.com", "http://example.com/media/"
Brian Moe's avatar
Brian Moe committed

# URL prefix for admin media -- CSS, JavaScript and images. Make sure to use a
# trailing slash.
# Examples: "http://foo.com/media/", "/media/".
ADMIN_MEDIA_PREFIX = '/media/'

# Make this unique, and don't share it with anybody.
SECRET_KEY = DEFAULT_SECRET_KEY
Brian Moe's avatar
Brian Moe committed

# New template settings compatible with Django 1.8
TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [
            '/home/gracedb/gracedb/templates',
        ],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                # Defaults
                'django.contrib.auth.context_processors.auth',
                'django.template.context_processors.debug',
                'django.template.context_processors.i18n',
                'django.template.context_processors.media',
                'django.template.context_processors.static',
                'django.template.context_processors.request',
                'gracedb.middleware.auth.LigoAuthContext',
                'middleware.debug.LigoDebugContext',
                'ligoauth.context_processors.shib_login_url',
            ],
        },
    },
]

Brian Moe's avatar
Brian Moe committed

#   'gracedb.middleware.auth.LigoAuthBackend',
    'ligoauth.middleware.auth.LigoX509Backend',
    'ligoauth.middleware.auth.LigoShibBackend',
    'ligoauth.middleware.auth.LigoBasicBackend',
#   'ligoauth.middleware.auth.RemoteUserBackend',
#   'ligodjangoauth.LigoShibbolethAuthBackend',
#   'django.contrib.auth.backends.ModelBackend',
    'guardian.backends.ObjectPermissionBackend',
ANONYMOUS_USER_ID = -1
GUARDIAN_RENDER_403 = True
# URL of Shibboleth login page
# If these are left at default, when the Shibboleth middleware
# creates a new auth_user, they will get admin privs.
ADMIN_GROUP_HEADER = None
ADMIN_GROUP = None

Brian Moe's avatar
Brian Moe committed
MIDDLEWARE_CLASSES = [
    'middleware.performance.PerformanceMiddleware',
    'middleware.accept.AcceptMiddleware',
    'middleware.cli.CliExceptionMiddleware',
Brian Moe's avatar
Brian Moe committed
    'django.middleware.common.CommonMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
#   'django.contrib.auth.middleware.AuthenticationMiddleware',
#   'ligodjangoauth.LigoShibbolethMiddleware',
    'ligoauth.middleware.auth.LigoAuthMiddleware',
#   'django.contrib.auth.middleware.RemoteUserMiddleware',
    'maintenancemode.middleware.MaintenanceModeMiddleware',
Brian Moe's avatar
Brian Moe committed
]
Brian Moe's avatar
Brian Moe committed

ROOT_URLCONF = 'urls'
Brian Moe's avatar
Brian Moe committed

INSTALLED_APPS = (
    'django.contrib.auth',
Brian Moe's avatar
Brian Moe committed
    'django.contrib.admin',
Brian Moe's avatar
Brian Moe committed
    'django.contrib.contenttypes',
    'django.contrib.sessions',
#    'django.contrib.sites',
Brian Moe's avatar
Brian Moe committed
    'django.contrib.staticfiles',
    'gracedb',
    'userprofile',
    'ligoauth',
Brian Moe's avatar
Brian Moe committed
    'rest_framework',
    'django_twilio',
Brian Moe's avatar
Brian Moe committed
)
Brian Moe's avatar
Brian Moe committed

REST_FRAMEWORK = {
    'PAGINATE_BY': 10,
    'DEFAULT_THROTTLE_RATES': {
        'event_creation': '1/second',
        'annotation'    : '10/second',
    },
Brian Moe's avatar
Brian Moe committed
}

# Location of static components, CSS, JS, etc.
Brian Moe's avatar
Brian Moe committed
STATIC_URL = "/gracedb-static/"
STATIC_ROOT = "/home/gracedb/gracedb/static/"
Brian Moe's avatar
Brian Moe committed
STATICFILES_FINDERS = (
    'django.contrib.staticfiles.finders.FileSystemFinder',
    'django.contrib.staticfiles.finders.AppDirectoriesFinder',
#    'django.contrib.staticfiles.finders.DefaultStorageFinder',
)
STATICFILES_DIRS = ()
# Location of Bower packages.
BOWER_URL = "/bower-static/"
BOWER_ROOT = "/home/gracedb/bower_components/"

# Added in order to perform data migrations on the auth app
MIGRATION_MODULES = {
    'auth' : 'migrations.auth',
    'guardian' : 'migrations.guardian',
}
# Passwords for LVEM scripted access expire after 365 days.
PASSWORD_EXPIRATION_TIME = timedelta(days=365)

# LIGO control room IPs
CONTROL_ROOM_IPS = {
    'H1': '198.129.208.178',
    'L1': '208.69.128.41',
# Everything below here is logging. ###########################################

# Filter objects to separate out each level of alert.
class infoOnlyFilter(logging.Filter):
    def filter(self,record):
        if record.levelname=='INFO':
            return 1
        return 0

LOG_ROOT = '/home/gracedb/logs'
LOG_FILE_SIZE = 1024*1024 # 1 MB
LOG_FILE_BAK_CT = 10
LOG_FORMAT = 'extra_verbose'
LOG_LEVEL = 'DEBUG'

# Note that mode for log files is 'a' (append) by default
# The 'level' specifier on the handle is optional, and we
# don't need it since we're using custom filters.
            'format': '%(asctime)s | %(message)s',
            'datefmt': '%Y-%m-%d %H:%M:%S',
        'verbose': {
            'format': '%(asctime)s | %(name)s | %(message)s',
            'datefmt': '%Y-%m-%d %H:%M:%S',
        },
        'extra_verbose': {
            'format': '%(asctime)s.%(msecs)03d | %(name)s | %(levelname)s | ' \
                      + '%(filename)s, line %(lineno)s | %(message)s',
            'datefmt': '%Y-%m-%d %H:%M:%S',
        }
            'level': 'DEBUG',
            'class': 'django.utils.log.NullHandler',
        'debug_file': {
            'class': 'logging.handlers.ConcurrentRotatingFileHandler',
            'formatter': LOG_FORMAT,
            'filename': '%s/gracedb_debug.log' % LOG_ROOT,
            'backupCount': LOG_FILE_BAK_CT,
            'level': 'DEBUG',
        },
        'error_file': {
            'class': 'logging.handlers.ConcurrentRotatingFileHandler',
            'formatter': LOG_FORMAT,
            'filename': '%s/gracedb_error.log' % LOG_ROOT,
            'maxBytes': LOG_FILE_SIZE,
            'backupCount': LOG_FILE_BAK_CT,
            'level': 'ERROR',
            'formatter': 'simple',
            'filename': '%s/gracedb_performance.log' % LOG_ROOT,
        },
        'mail_admins': {
            'level': 'ERROR',
            'class': 'django.utils.log.AdminEmailHandler'
        }
    },
    'loggers': {
        'django': {
            'handlers': ['null'],
            'propagate': True,
            'level': 'INFO',
        },
            'propagate': True,
            'level': LOG_LEVEL,
        },
        'userprofile': {
        'middleware': {
            'handlers': ['performance_file'],
            'propagate': True,
            'level': 'INFO',
        },
            'level': 'ERROR',