import logging
+import dbus
import telepathy
-import gtk_toolbox
+import util.misc as misc_utils
import tp
import handle
import gvoice.state_machine as state_machine
-_moduleLogger = logging.getLogger("simple_presence")
+_moduleLogger = logging.getLogger(__name__)
class TheOneRingPresence(object):
OFFLINE = 'offline'
TO_PRESENCE_TYPE = {
- ONLINE: telepathy.constants.CONNECTION_PRESENCE_TYPE_AVAILABLE,
- AWAY: telepathy.constants.CONNECTION_PRESENCE_TYPE_AWAY,
- HIDDEN: telepathy.constants.CONNECTION_PRESENCE_TYPE_HIDDEN,
- OFFLINE: telepathy.constants.CONNECTION_PRESENCE_TYPE_OFFLINE,
+ ONLINE: dbus.UInt32(telepathy.constants.CONNECTION_PRESENCE_TYPE_AVAILABLE),
+ AWAY: dbus.UInt32(telepathy.constants.CONNECTION_PRESENCE_TYPE_AWAY),
+ HIDDEN: dbus.UInt32(telepathy.constants.CONNECTION_PRESENCE_TYPE_HIDDEN),
+ OFFLINE: dbus.UInt32(telepathy.constants.CONNECTION_PRESENCE_TYPE_OFFLINE),
}
+ def __init__(self, ignoreDND):
+ self.__ignoreDND = ignoreDND
+
@property
def session(self):
"""
def get_presences(self, contactIds):
"""
- @bug On Maemo 5, the connection handle is being passed in a lot, forcing lots of downloads is the webpage for dnd
-
@return {ContactHandle: (Status, Presence Type, Message)}
"""
presences = {}
for handleId in contactIds:
h = self.get_handle_by_id(telepathy.HANDLE_TYPE_CONTACT, handleId)
if isinstance(h, handle.ConnectionHandle):
- isDnd = self.session.backend.is_dnd()
+ isDnd = self.session.is_dnd() if not self.__ignoreDND else False
if isDnd:
presence = TheOneRingPresence.HIDDEN
else:
raise telepathy.errors.InvalidArgument("Unsupported state on the state machine: %s" % state)
presenceType = TheOneRingPresence.TO_PRESENCE_TYPE[presence]
else:
- presence = TheOneRingPresence.ONLINE
+ presence = TheOneRingPresence.AWAY
presenceType = TheOneRingPresence.TO_PRESENCE_TYPE[presence]
presences[h] = (presenceType, presence)
def set_presence(self, status):
if status == self.ONLINE:
- self.session.backend.set_dnd(False)
+ if not self.__ignoreDND:
+ self.session.set_dnd(False)
self.session.stateMachine.set_state(state_machine.StateMachine.STATE_ACTIVE)
elif status == self.AWAY:
self.session.stateMachine.set_state(state_machine.StateMachine.STATE_IDLE)
elif status == self.HIDDEN:
- self.session.backend.set_dnd(True)
+ if not self.__ignoreDND:
+ self.session.set_dnd(True)
elif status == self.OFFLINE:
self.Disconnect()
else:
_moduleLogger.info("Setting Presence to '%s'" % status)
-class SimplePresenceMixin(tp.ConnectionInterfaceSimplePresence, TheOneRingPresence):
+class SimplePresenceMixin(tp.ConnectionInterfaceSimplePresence):
- def __init__(self):
+ def __init__(self, torPresence):
tp.ConnectionInterfaceSimplePresence.__init__(self)
- TheOneRingPresence.__init__(self)
+ self.__torPresence = torPresence
self._implement_property_get(
tp.CONNECTION_INTERFACE_SIMPLE_PRESENCE,
{'Statuses' : self._get_statuses}
)
- @gtk_toolbox.log_exception(_moduleLogger)
+ @misc_utils.log_exception(_moduleLogger)
def GetPresences(self, contacts):
"""
@return {ContactHandle: (Status, Presence Type, Message)}
"""
personalMessage = u""
- return dict(
- (h, (presenceType, presence, personalMessage))
- for (h, (presenceType, presence)) in self.get_presences(contacts).iteritems()
+ return dbus.Dictionary(
+ (
+ (h, dbus.Struct((presenceType, presence, personalMessage), signature="uss"))
+ for (h, (presenceType, presence)) in
+ self.__torPresence.get_presences(contacts).iteritems()
+ ),
+ signature="u(uss)"
)
- @gtk_toolbox.log_exception(_moduleLogger)
+ @misc_utils.log_exception(_moduleLogger)
def SetPresence(self, status, message):
if message:
raise telepathy.errors.InvalidArgument("Messages aren't supported")
- self.set_presence(status)
+ self.__torPresence.set_presence(status)
def _get_statuses(self):
"""
"""
return dict(
(localType, (telepathyType, True, False))
- for (localType, telepathyType) in self.TO_PRESENCE_TYPE.iteritems()
+ for (localType, telepathyType) in self.__torPresence.TO_PRESENCE_TYPE.iteritems()
)