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.
293 lines
11 KiB
293 lines
11 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! ##
|
|
## ##
|
|
#################################################################
|
|
#################################################################
|
|
|
|
# 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__)))
|
|
|
|
BASE_DIR = MUMBLE_DJANGO_ROOT
|
|
|
|
# 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
|
|
|
|
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 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)
|
|
|
|
|
|
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 = '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.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' )
|