mirror of
https://github.com/nikdoof/mumblepy.git
synced 2025-12-18 04:09:23 +00:00
Add docstrings to the User class.
This commit is contained in:
@@ -8,130 +8,168 @@ class User(object):
|
||||
|
||||
@property
|
||||
def session(self):
|
||||
"""Return the session ID of the user."""
|
||||
return self.__user.session
|
||||
|
||||
@property
|
||||
def id(self):
|
||||
"""Return the user ID of the user, if they are registered."""
|
||||
return self.__user.userid
|
||||
|
||||
@property
|
||||
def muted(self):
|
||||
"""Indicates if the user is currently muted."""
|
||||
return bool(self.__user.mute)
|
||||
|
||||
@property
|
||||
def deafened(self):
|
||||
"""Indiciates if the user is currently deafened"""
|
||||
return bool(self.__user.deaf)
|
||||
|
||||
@property
|
||||
def suppress(self):
|
||||
"""Indiciates if the user has been suppressed by the server due to lack of permissions"""
|
||||
return bool(self.__user.suppress)
|
||||
|
||||
@property
|
||||
def priority_speaker(self):
|
||||
"""Indiciates if the user is currently a Priority Speaker"""
|
||||
return bool(self.__user.prioritySpeaker)
|
||||
|
||||
@property
|
||||
def self_muted(self):
|
||||
"""Indiciates if the user has self muted."""
|
||||
return bool(self.__user.selfMute)
|
||||
|
||||
@property
|
||||
def self_deafened(self):
|
||||
"""Indiciates if the user is self-deafened."""
|
||||
return bool(self.__user.selfDeaf)
|
||||
|
||||
@property
|
||||
def channel(self):
|
||||
"""Returns the ``Channel`` object for the user's current channel"""
|
||||
return self.__server.get_channel(self.__user.channel)
|
||||
|
||||
@property
|
||||
def name(self):
|
||||
"""The user's display name"""
|
||||
return self.__user.name
|
||||
|
||||
@property
|
||||
def online_seconds(self):
|
||||
"""Returns the number of seconds the user has been connected to the server."""
|
||||
return self.__user.onlinesecs
|
||||
|
||||
@property
|
||||
def bytes_per_second(self):
|
||||
"""Returns the current bps speed of the user's connection to Mumble."""
|
||||
return self.__user.bytespersec
|
||||
|
||||
@property
|
||||
def client_version(self):
|
||||
"""Returns the version of the user's Mumble client."""
|
||||
return self.__user.osversion
|
||||
|
||||
@property
|
||||
def client_release(self):
|
||||
"""Returns the release of the user's Mumble client."""
|
||||
return self.__user.release
|
||||
|
||||
@property
|
||||
def plugin_identity(self):
|
||||
"""If a plugin is active for the user, this returns the plugin's identity"""
|
||||
return self.__user.identity
|
||||
|
||||
@property
|
||||
def os(self):
|
||||
"""The user's current operating system"""
|
||||
return self.__user.os
|
||||
|
||||
@property
|
||||
def os_version(self):
|
||||
"""The user's operating system release/version"""
|
||||
return self.__user.osversion
|
||||
|
||||
@property
|
||||
def plugin_context(self):
|
||||
"""If a plugin is currently active for the user, this returns their context"""
|
||||
return self.__user.context
|
||||
|
||||
@property
|
||||
def comment(self):
|
||||
"""Returns the user's set comment."""
|
||||
return self.__user.comment
|
||||
|
||||
@property
|
||||
def ip_address(self):
|
||||
"""Returns a tuple of the user's IP address in IPv6 format"""
|
||||
return self.__user.address
|
||||
|
||||
@property
|
||||
def tcp_only(self):
|
||||
"""Indiciates if the user is connected via a TCP only connection."""
|
||||
return bool(self.__user.tcponly)
|
||||
|
||||
@property
|
||||
def idle_seconds(self):
|
||||
"""Returns the number of seconds the user has been idle."""
|
||||
return self.__user.idlesecs
|
||||
|
||||
def update(self, **kwargs):
|
||||
"""Update a value of the user's state.kwargs
|
||||
|
||||
Generally its advised to use one of the other functions (mute/deafen) to change the user's state, unless
|
||||
its isn't covered by the class' API.
|
||||
"""
|
||||
for key, value in kwargs.items():
|
||||
setattr(self.__user, key, value)
|
||||
self.__server.set_user_state(self.__user)
|
||||
|
||||
def send_message(self, text):
|
||||
"""Send a message to the user via Mumble's chat feature"""
|
||||
return self.__server.send_user_message(self.__user.session, text)
|
||||
|
||||
def mute(self):
|
||||
"""Mute the user."""
|
||||
return self.update(mute=1)
|
||||
|
||||
def deafen(self):
|
||||
"""Deafen the user."""
|
||||
return self.update(deaf=1)
|
||||
|
||||
def unmute(self):
|
||||
"""Unmute the user."""
|
||||
return self.update(mute=0)
|
||||
|
||||
def undeafen(self):
|
||||
"""Undeafen the user."""
|
||||
return self.update(deaf=0)
|
||||
|
||||
def priority_speaker(self):
|
||||
"""Enable priority speaker for the user."""
|
||||
return self.update(prioritySpeaker=1)
|
||||
|
||||
def remove_priority_speaker(self):
|
||||
"""Remove priority speaker from the user."""
|
||||
return self.update(prioritySpeaker=0)
|
||||
|
||||
def move(self, channel):
|
||||
"""Move the user to the specified channel."""
|
||||
if isinstance(channel, int):
|
||||
return self.update(channel=channel)
|
||||
return self.update(channel=channel.id)
|
||||
|
||||
def kick(self, reason=''):
|
||||
"""Kick the user from the server"""
|
||||
return self.__server.kick_user(self.__user.session, reason)
|
||||
|
||||
def ban(self, reason='', bits=128, duration=360):
|
||||
"""Ban the user from the server"""
|
||||
return self.__server.add_ban(self.__user.address, reason, bits, duration)
|
||||
|
||||
def serialize(self):
|
||||
"""Returns the user's state in a standard ``dict``"""
|
||||
return {
|
||||
'session': self.__user.session,
|
||||
'id': self.__user.userid,
|
||||
|
||||
Reference in New Issue
Block a user