Forked mumble-django project from https://bitbucket.org/Svedrin/mumble-django
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

309 lines
12 KiB

# -*- coding: utf-8 -*-
# kate: space-indent on; indent-width 4; replace-tabs on;
# Django settings for mumble_django project.
"""
* Copyright © 2009-2010, Michael "Svedrin" Ziegler <diese-addy@funzt-halt.net>
*
* Mumble-Django is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This package is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
"""
#################################################################
#################################################################
## ##
## The slice to use for communication over ZeroC Ice. ##
## This must be set to the path to the Murmur.ice file that ##
## resides in your Murmur directory. ##
## Not used on recent Murmur versions, because the slice file ##
## can be retrieved from Murmur directly. ##
SLICE = '/usr/share/slice/Murmur.ice' ##
## ##
## The include dir to pass to Ice. Set this to a path in which ##
## $SLICEDIR/Ice/SliceChecksumDict.ice exists. ##
## Not used on recent Ice versions, because the SLICEDIR can ##
## be retrieved from Ice directly. ##
SLICEDIR = '/usr/share/Ice/slice' ##
## ##
#################################################################
## ##
## The path inside the VirtualHost that M-D lives in: ##
## ##
MUMBLE_DJANGO_URL = '/' ##
#MUMBLE_DJANGO_URL = '/mumble-django/' ##
## ##
## Make sure you use a trailing slash! ##
## ##
#################################################################
## ##
## Mumble-Django will try to auto-detect this value if it ##
## isn't set, which is the default. However, if this should ##
## not work as expected, set this to the path where you ##
## extracted Mumble-Django. ##
## ##
## Default: Auto Detection ##
MUMBLE_DJANGO_ROOT = None ##
## Examples: ##
#MUMBLE_DJANGO_ROOT = '/srv/mumble-django' ##
#MUMBLE_DJANGO_ROOT = 'c:/web/mumble-django' ##
## ##
#################################################################
## ##
## For a basic installation, this is all you need to edit in ##
## this file, the rest will be handled automatically! ##
## ##
#################################################################
#################################################################
# Who will receive emails on errors?
ADMINS = (
# ('Your Name', 'your_email@domain.com'),
)
# Show debug information on errors?
# If you want to file a bug report, please enable this option.
DEBUG = True
# These IPs will be delivered the debug templates if DEBUG == True.
INTERNAL_IPS = ['127.0.0.1']
# 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 = 'Europe/Berlin'
# Language code for this installation. All choices can be found here:
# http://www.i18nguy.com/unicode/language-identifiers.html
LANGUAGE_CODE = 'en-us'
# The Theme to use. None for the builtin theme.
THEME = None
# URL Template for constructing Gravatars.
GRAVATAR_URL = 'http://www.gravatar.com/avatar/%(hash)s.jpg?d=monsterid&s=%(size)d'
# Automatically set the Gravatar as the user's avatar when creating new users?
USE_GRAVATAR = True
# The default connection string to set for newly created instances.
# Ice:
DEFAULT_CONN = 'Meta:tcp -h 127.0.0.1 -p 6502'
# DBus:
#DEFAULT_CONN = 'net.sourceforge.mumble.murmur'
# Default email address to send mails from.
DEFAULT_FROM_EMAIL = "webmaster@localhost"
# Length of the account activation period, in days.
ACCOUNT_ACTIVATION_DAYS = 30
# Should subchannels be shown, even if there are no players in them?
SHOW_EMPTY_SUBCHANS = False
# Protect the registration form for private servers?
# If set to True, people will need to enter the server password in order to create accounts,
# and will not be able to link existing accounts.
PROTECTED_MODE = False
# Account linking allows users who registered their accounts through Mumble instead of using
# Mumble-Django, to tell MD that this account belongs to them. Then they can use MD to change
# their passwords.
# This will of course require them to enter the password that belongs to the Murmur account,
# and the accounts will only be linked if the password is correct.
# By default, this is enabled only for non-admin accounts, because if an admin account gets
# stolen they could easily take over the server. (So make sure the password can't be easily
# guessed, use at least over 9000 letters, blah blah.)
# This feature is only available if PROTECTED_MODE is not active.
ALLOW_ACCOUNT_LINKING = True # Allow linking in general?
ALLOW_ACCOUNT_LINKING_ADMINS = False # Allow linking for Admin accounts?
# Warning and Critical levels for the Munin plugin. These will be multiplied with the
# server instance's slot count to calculate the real levels.
MUNIN_WARNING = 0.80
MUNIN_CRITICAL = 0.95
# The graph title.
MUNIN_TITLE = 'Mumble Users'
# see <http://munin.projects.linpro.no/wiki/graph_category_list> for a list of valid categories.
MUNIN_CATEGORY = 'mumble'
# Set to True if you do not wish offline servers to appear in the server list.
HIDE_OFFLINE_SERVERS=False
# True to display users above channels in the channel viewer.
USERS_ABOVE_CHANNELS=False
###################################################################
## ##
## The following settings normally do not require changes, and ##
## you should only change them if you know what you're doing. ##
## ##
###################################################################
from os.path import join, dirname, abspath, exists
if not MUMBLE_DJANGO_ROOT or not exists( MUMBLE_DJANGO_ROOT ):
MUMBLE_DJANGO_ROOT = dirname(dirname(abspath(__file__)))
# Default mumble port. If your server runs under this port, it will not be
# included in the links in the Channel Viewer.
MUMBLE_DEFAULT_PORT = 64738
if not MUMBLE_DJANGO_URL:
MUMBLE_DJANGO_URL = '/'
elif MUMBLE_DJANGO_URL[-1] != '/':
MUMBLE_DJANGO_URL = MUMBLE_DJANGO_URL + '/'
# Database settings for Mumble-Django's database. These do NOT need to point
# to Murmur's database, Mumble-Django should use its own!
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': join( MUMBLE_DJANGO_ROOT, 'db', 'mumble-django.db3' ),
'USER': '',
'PASSWORD': '',
'HOST': '',
'PORT': '',
}
}
# Email settings. only change if the defaults don't work
#EMAIL_HOST = "localhost"
#EMAIL_PORT = 25
#EMAIL_HOST_USER = ""
#EMAIL_HOST_PASSWORD = ""
#EMAIL_USE_TLS = True
TEMPLATE_DEBUG = DEBUG
MANAGERS = ADMINS
SITE_ID = 1
# If you set this to False, Django will make some optimizations so as not
# to load the internationalization machinery.
USE_I18N = True
USE_L10N = True
STATIC_URL = MUMBLE_DJANGO_URL + 'static/'
STATICFILES_DIRS = (
join( MUMBLE_DJANGO_ROOT, 'htdocs' ),
)
## URL to static files of the currently active theme
THEME_URL = '%sstatic/themes/%s/' % ( MUMBLE_DJANGO_URL, THEME )
# URL prefix for admin media -- CSS, JavaScript and images.
ADMIN_MEDIA_PREFIX = MUMBLE_DJANGO_URL + 'static/admin/'
# URL to the login view
LOGIN_URL = MUMBLE_DJANGO_URL + 'accounts/login'
LOGIN_REDIRECT_URL = MUMBLE_DJANGO_URL + 'accounts/profile'
# Automatically generate a .secret.txt file containing the SECRET_KEY.
# Shamelessly stolen from ByteFlow: <http://www.byteflow.su>
try:
SECRET_KEY
except NameError:
SECRET_FILE = join(MUMBLE_DJANGO_ROOT, '.secret.txt')
try:
SECRET_KEY = open(SECRET_FILE).read().strip()
except IOError:
try:
from random import choice
SECRET_KEY = ''.join([choice('abcdefghijklmnopqrstuvwxyz0123456789!@#$%^&*(-_=+)') for i in range(50)])
secret = file(SECRET_FILE, 'w')
secret.write(SECRET_KEY)
secret.close()
except IOError:
Exception('Please create a %s file with random characters to generate your secret key!' % SECRET_FILE)
# List of callables that know how to import templates from various sources.
TEMPLATE_LOADERS = (
'django.template.loaders.filesystem.Loader',
'django.template.loaders.app_directories.Loader',
# 'django.template.loaders.eggs.Loader',
)
MIDDLEWARE_CLASSES = (
'django.middleware.common.CommonMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.middleware.locale.LocaleMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware'
)
ROOT_URLCONF = 'pyweb.urls'
if THEME:
TEMPLATE_DIRS = [ join( MUMBLE_DJANGO_ROOT, 'themes', THEME ) ]
else:
TEMPLATE_DIRS = []
TEMPLATE_DIRS.extend((
# Put strings here, like "/home/html/django_templates" or "C:/www/django/templates".
# Always use forward slashes, even on Windows.
# Don't forget to use absolute paths, not relative paths.
join( MUMBLE_DJANGO_ROOT, 'pyweb', 'templates' ),
))
TEMPLATE_CONTEXT_PROCESSORS = [
"django.contrib.auth.context_processors.auth",
"django.core.context_processors.debug",
"django.core.context_processors.i18n",
"django.core.context_processors.media",
'processors.installed_apps',
'processors.mumble_version',
'processors.mumble_media_prefix',
]
if THEME:
TEMPLATE_CONTEXT_PROCESSORS.append('processors.theme_url')
#TEST_RUNNER = 'mumble.testrunner.run_tests'
#TEST_MURMUR_LAB_DIR = join( dirname(MUMBLE_DJANGO_ROOT), 'murmur' )
#TEST_MURMUR_FILES_DIR = join( MUMBLE_DJANGO_ROOT, 'testdata' )
CONVERSIONSQL_ROOT = join( MUMBLE_DJANGO_ROOT, "pyweb", "mumble", "conversionsql" )
INSTALLED_APPS = [
'django.contrib.auth',
'django.contrib.admin',
'django.contrib.admindocs',
'django.contrib.contenttypes',
'django.contrib.messages',
'django.contrib.markup',
'django.contrib.staticfiles',
'django.contrib.sessions',
'django.contrib.sites',
'mumble',
]
def modprobe( name ):
""" Try to import the named module, and if that works add it to INSTALLED_APPS. """
try:
__import__( name )
except ImportError:
pass
else:
INSTALLED_APPS.append( name )
# Check if rosetta is available.
# http://code.google.com/p/django-rosetta
modprobe( "rosetta" )
# Check if django_extensions is available.
modprobe( "django_extensions" )
#modprobe( 'registration' )