-import weakref
import logging
+import dbus
import telepathy
+import tp
import channel
+import util.misc as misc_utils
_moduleLogger = logging.getLogger("channel_manager")
-class ChannelManager(object):
+class ChannelManager(tp.ChannelManager):
def __init__(self, connection):
- self._connRef = weakref.ref(connection)
- self._listChannels = weakref.WeakValueDictionary()
- self._textChannels = weakref.WeakValueDictionary()
- self._callChannels = weakref.WeakValueDictionary()
-
- def close(self):
- for chan in self._listChannels.values():
- chan.remove_from_connection()# so that dbus lets it die.
- for chan in self._textChannels.values():
- chan.Close()
- for chan in self._callChannels.values():
- chan.Close()
-
- def channel_for_list(self, handle, suppress_handler=False):
- if handle in self._listChannels:
- chan = self._listChannels[handle]
- else:
- if handle.get_type() == telepathy.HANDLE_TYPE_GROUP:
- chan = channel.contact_list.GroupChannel(self._connRef(), handle)
- elif handle.get_type() == telepathy.HANDLE_TYPE_CONTACT:
- chan = channel.contact_list.creat_contact_list_channel(self._connRef(), handle)
- else:
- _moduleLogger.warn("Unknown channel type %r" % handle.get_type())
- self._listChannels[handle] = chan
- self._connRef().add_channel(chan, handle, suppress_handler)
+ tp.ChannelManager.__init__(self, connection)
+
+ fixed = {
+ telepathy.CHANNEL_INTERFACE + '.ChannelType': telepathy.CHANNEL_TYPE_CONTACT_LIST
+ }
+ self._implement_channel_class(
+ telepathy.CHANNEL_TYPE_CONTACT_LIST,
+ self._get_list_channel,
+ fixed,
+ []
+ )
+
+ fixed = {
+ telepathy.CHANNEL_INTERFACE + '.ChannelType': telepathy.CHANNEL_TYPE_TEXT,
+ telepathy.CHANNEL_INTERFACE + '.TargetHandleType': dbus.UInt32(telepathy.HANDLE_TYPE_CONTACT)
+ }
+ self._implement_channel_class(
+ telepathy.CHANNEL_TYPE_TEXT,
+ self._get_text_channel,
+ fixed,
+ []
+ )
+
+ fixed = {
+ telepathy.CHANNEL_INTERFACE + '.ChannelType': telepathy.CHANNEL_TYPE_FILE_TRANSFER,
+ telepathy.CHANNEL_INTERFACE + '.TargetHandleType': dbus.UInt32(telepathy.HANDLE_TYPE_CONTACT)
+ }
+ self._implement_channel_class(
+ telepathy.CHANNEL_TYPE_FILE_TRANSFER,
+ self._get_file_transfer_channel,
+ fixed,
+ []
+ )
+
+ fixed = {
+ telepathy.CHANNEL_INTERFACE + '.ChannelType': telepathy.CHANNEL_TYPE_STREAMED_MEDIA,
+ telepathy.CHANNEL_INTERFACE + '.TargetHandleType': dbus.UInt32(telepathy.HANDLE_TYPE_CONTACT)
+ }
+ self._implement_channel_class(
+ telepathy.CHANNEL_TYPE_STREAMED_MEDIA,
+ self._get_media_channel,
+ fixed,
+ [telepathy.CHANNEL_INTERFACE + '.TargetHandle']
+ )
+
+ def _get_list_channel(self, props):
+ _, surpress_handler, h = self._get_type_requested_handle(props)
+
+ _moduleLogger.debug('New contact list channel')
+ chan = channel.contact_list.create_contact_list_channel(self._conn, self, props, h)
return chan
- def channel_for_text(self, handle, suppress_handler=False):
- if handle in self._textChannels:
- chan = self._textChannels[handle]
+ def _get_text_channel(self, props):
+ _, surpress_handler, h = self._get_type_requested_handle(props)
+
+ accountNumber = misc_utils.normalize_number(self._conn.session.backend.get_account_number())
+ if h.phoneNumber == accountNumber:
+ _moduleLogger.debug('New Debug channel')
+ chan = channel.debug_prompt.DebugPromptChannel(self._conn, self, props, h)
else:
- _moduleLogger.debug("Requesting new text channel")
- contact = handle.contact
+ _moduleLogger.debug('New text channel')
+ chan = channel.text.TextChannel(self._conn, self, props, h)
+ return chan
- chan = channel.text.TextChannel(self._connRef())
- self._textChannels[handle] = chan
- self._connRef().add_channel(chan, handle, suppress_handler)
+ def _get_file_transfer_channel(self, props):
+ _, surpress_handler, h = self._get_type_requested_handle(props)
+
+ _moduleLogger.debug('New file transfer channel')
+ chan = channel.debug_log.DebugLogChannel(self._conn, self, props, h)
return chan
- def channel_for_call(self, handle, suppress_handler=False):
- if handle in self._callChannels:
- chan = self._callChannels[handle]
- else:
- _moduleLogger.debug("Requesting new call channel")
- contact = handle.contact
+ def _get_media_channel(self, props):
+ _, surpress_handler, h = self._get_type_requested_handle(props)
- chan = channel.call.CallChannel(self._connRef())
- self._callChannels[handle] = chan
- self._connRef().add_channel(chan, handle, suppress_handler)
+ _moduleLogger.debug('New media channel')
+ chan = channel.call.CallChannel(self._conn, self, props, h)
return chan