Browse Source

normalize server connectivity info into MumbleServer model

Natenom/support-murmur-13-1446181288462
Michael Ziegler 15 years ago
parent
commit
06af88eb89
  1. 3
      pyweb/mumble/admin.py
  2. 3
      pyweb/mumble/forms.py
  3. 9
      pyweb/mumble/management/server_detect.py
  4. 61
      pyweb/mumble/models.py

3
pyweb/mumble/admin.py

@ -18,7 +18,7 @@ from django.contrib import admin
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
from mumble.forms import MumbleAdminForm, MumbleUserAdminForm from mumble.forms import MumbleAdminForm, MumbleUserAdminForm
from mumble.models import Mumble, MumbleUser
from mumble.models import MumbleServer, Mumble, MumbleUser
class MumbleAdmin(admin.ModelAdmin): class MumbleAdmin(admin.ModelAdmin):
""" Specification for the "Server administration" admin section. """ """ Specification for the "Server administration" admin section. """
@ -97,5 +97,6 @@ class MumbleUserAdmin(admin.ModelAdmin):
get_acl_admin.boolean = True get_acl_admin.boolean = True
admin.site.register( MumbleServer );
admin.site.register( Mumble, MumbleAdmin ); admin.site.register( Mumble, MumbleAdmin );
admin.site.register( MumbleUser, MumbleUserAdmin ); admin.site.register( MumbleUser, MumbleUserAdmin );

3
pyweb/mumble/forms.py

@ -107,7 +107,7 @@ class MumbleForm( PropertyModelForm ):
class Meta: class Meta:
model = Mumble; model = Mumble;
exclude = ( 'dbus', 'addr', 'port', 'secret' );
fields = ['name'];
class MumbleAdminForm( MumbleForm ): class MumbleAdminForm( MumbleForm ):
@ -121,6 +121,7 @@ class MumbleAdminForm( MumbleForm ):
class Meta: class Meta:
fields = None
exclude = None exclude = None
def clean_port( self ): def clean_port( self ):

9
pyweb/mumble/management/server_detect.py

@ -92,14 +92,21 @@ def find_existing_instances( **kwargs ):
servIDs = ctl.getAllServers(); servIDs = ctl.getAllServers();
try:
meta = models.MumbleServer.objects.get( dbus=dbusName );
except models.MumbleServer.DoesNotExist:
meta = models.MumbleServer( dbus=dbusName );
meta.save();
for id in servIDs: for id in servIDs:
if v > 1: if v > 1:
print "Checking Murmur instance with id %d." % id; print "Checking Murmur instance with id %d." % id;
# first check that the server has not yet been inserted into the DB # first check that the server has not yet been inserted into the DB
try: try:
instance = models.Mumble.objects.get( dbus=dbusName, srvid=id );
instance = models.Mumble.objects.get( server=meta, srvid=id );
except models.Mumble.DoesNotExist: except models.Mumble.DoesNotExist:
values = { values = {
"server": meta,
"srvid": id, "srvid": id,
"dbus": dbusName, "dbus": dbusName,
} }

61
pyweb/mumble/models.py

@ -41,6 +41,37 @@ def mk_config_property( field, doc="" ):
return property( get_field, set_field, doc=doc ) return property( get_field, set_field, doc=doc )
class MumbleServer( models.Model ):
""" Represents a Murmur server installation. """
dbus = models.CharField( _('DBus or ICE base'), max_length=200, unique=True, default=settings.DEFAULT_CONN, help_text=_(
"Examples: 'net.sourceforge.mumble.murmur' for DBus or 'Meta:tcp -h 127.0.0.1 -p 6502' for Ice.") );
secret = models.CharField( _('Ice Secret'), max_length=200, blank=True );
class Meta:
verbose_name = _('Mumble Server');
verbose_name_plural = _('Mumble Servers');
def __init__( self, *args, **kwargs ):
models.Model.__init__( self, *args, **kwargs );
self._ctl = None;
def __unicode__( self ):
return self.dbus;
# Ctl instantiation
def getCtl( self ):
""" Instantiate and return a MumbleCtl object for this server.
Only one instance will be created, and reused on subsequent calls.
"""
if not self._ctl:
self._ctl = MumbleCtlBase.newInstance( self.dbus, settings.SLICE, self.secret );
return self._ctl;
ctl = property( getCtl, doc="Get a Control object for this server. The ctl is cached for later reuse." );
class Mumble( models.Model ): class Mumble( models.Model ):
""" Represents a Murmur server instance. """ Represents a Murmur server instance.
@ -56,9 +87,8 @@ class Mumble( models.Model ):
deleted as well. deleted as well.
""" """
server = models.ForeignKey( MumbleServer );
name = models.CharField( _('Server Name'), max_length=200 ); name = models.CharField( _('Server Name'), max_length=200 );
dbus = models.CharField( _('DBus or ICE base'), max_length=200, default=settings.DEFAULT_CONN, help_text=_(
"Examples: 'net.sourceforge.mumble.murmur' for DBus or 'Meta:tcp -h 127.0.0.1 -p 6502' for Ice.") );
srvid = models.IntegerField( _('Server ID'), editable=False ); srvid = models.IntegerField( _('Server ID'), editable=False );
addr = models.CharField( _('Server Address'), max_length=200, help_text=_( addr = models.CharField( _('Server Address'), max_length=200, help_text=_(
"Hostname or IP address to bind to. You should use a hostname here, because it will appear on the " "Hostname or IP address to bind to. You should use a hostname here, because it will appear on the "
@ -69,7 +99,6 @@ class Mumble( models.Model ):
"This field is only relevant if you are located behind a NAT, and names the Hostname or IP address " "This field is only relevant if you are located behind a NAT, and names the Hostname or IP address "
"to use in the Channel Viewer and for the global server list registration. If not given, the addr " "to use in the Channel Viewer and for the global server list registration. If not given, the addr "
"and port fields are used. If display and bind ports are equal, you can omit it here.") ); "and port fields are used. If display and bind ports are equal, you can omit it here.") );
secret = models.CharField( _('Ice Secret'), max_length=200, blank=True );
supw = property( lambda self: '', supw = property( lambda self: '',
lambda self, value: self.ctl.setSuperUserPassword( self.srvid, value ), lambda self, value: self.ctl.setSuperUserPassword( self.srvid, value ),
@ -109,7 +138,7 @@ class Mumble( models.Model ):
booted = property( getBooted, setBooted, doc="Boot Server" ) booted = property( getBooted, setBooted, doc="Boot Server" )
class Meta: class Meta:
unique_together = ( ( 'dbus', 'srvid' ), ( 'addr', 'port' ), );
unique_together = ( ( 'server', 'srvid' ), ( 'addr', 'port' ), );
verbose_name = _('Server instance'); verbose_name = _('Server instance');
verbose_name_plural = _('Server instances'); verbose_name_plural = _('Server instances');
@ -152,7 +181,6 @@ class Mumble( models.Model ):
def __init__( self, *args, **kwargs ): def __init__( self, *args, **kwargs ):
models.Model.__init__( self, *args, **kwargs ); models.Model.__init__( self, *args, **kwargs );
self._ctl = None;
self._channels = None; self._channels = None;
self._rootchan = None; self._rootchan = None;
@ -167,19 +195,7 @@ class Mumble( models.Model ):
is_channel = False; is_channel = False;
is_player = False; is_player = False;
# Ctl instantiation
def getCtl( self ):
""" Instantiate and return a MumbleCtl object for this server.
Only one instance will be created, and reused on subsequent calls.
"""
if not self._ctl:
self._ctl = MumbleCtlBase.newInstance( self.dbus, settings.SLICE, self.secret );
return self._ctl;
ctl = property( getCtl, doc="Get a Control object for this server. The ctl is cached for later reuse." );
ctl = property( lambda self: self.server.ctl );
def getConf( self, field ): def getConf( self, field ):
return self.ctl.getConf( self.srvid, field ) return self.ctl.getConf( self.srvid, field )
@ -383,6 +399,14 @@ class Mumble( models.Model ):
'root': self.rootchan.asDict() 'root': self.rootchan.asDict()
}; };
# "server" field protection
def __setattr__( self, name, value ):
if name == 'server':
if self.id is not None and self.server != value:
raise AttributeError( _( "This field must not be updated once the record has been saved." ) );
models.Model.__setattr__( self, name, value );
class MumbleUser( models.Model ): class MumbleUser( models.Model ):
@ -551,7 +575,6 @@ class MumbleUser( models.Model ):
# "server" field protection # "server" field protection
def __setattr__( self, name, value ): def __setattr__( self, name, value ):
if name == 'server': if name == 'server':
if self.id is not None and self.server != value: if self.id is not None and self.server != value:

Loading…
Cancel
Save