Add bits to handle join/leave activities
This commit is contained in:
parent
8152672e49
commit
290f2c2900
@ -28,17 +28,41 @@ _ACTIVITY_PATH = "/org/laptop/Sugar/Presence/Activities/"
|
|||||||
_ACTIVITY_INTERFACE = "org.laptop.Sugar.Presence.Activity"
|
_ACTIVITY_INTERFACE = "org.laptop.Sugar.Presence.Activity"
|
||||||
|
|
||||||
class TestActivity(dbus.service.Object):
|
class TestActivity(dbus.service.Object):
|
||||||
def __init__(self, bus_name, object_id, actid, name, color, atype):
|
def __init__(self, bus_name, object_id, actid, name, color, atype, properties):
|
||||||
self._actid = actid
|
self._actid = actid
|
||||||
self._aname = name
|
self._aname = name
|
||||||
self._color = color
|
self._color = color
|
||||||
self._type = atype
|
self._type = atype
|
||||||
|
self._properties = {}
|
||||||
|
for (key, value) in properties.items():
|
||||||
|
self._properties[str(key)] = str(value)
|
||||||
self._buddies = {}
|
self._buddies = {}
|
||||||
|
|
||||||
self._object_id = object_id
|
self._object_id = object_id
|
||||||
self._object_path = _ACTIVITY_PATH + str(self._object_id)
|
self._object_path = _ACTIVITY_PATH + str(self._object_id)
|
||||||
dbus.service.Object.__init__(self, bus_name, self._object_path)
|
dbus.service.Object.__init__(self, bus_name, self._object_path)
|
||||||
|
|
||||||
|
def add_buddy(self, buddy):
|
||||||
|
if self._buddies.has_key(buddy._key):
|
||||||
|
raise NotFoundError("Buddy already in activity")
|
||||||
|
self._buddies[buddy._key] = buddy
|
||||||
|
self.BuddyJoined(buddy._object_path)
|
||||||
|
|
||||||
|
def remove_buddy(self, buddy):
|
||||||
|
if not self._buddies.has_key(buddy._key):
|
||||||
|
raise NotFoundError("Buddy not in activity")
|
||||||
|
self.BuddyLeft(buddy._object_path)
|
||||||
|
del self._buddies[buddy._key]
|
||||||
|
|
||||||
|
def disappear(self):
|
||||||
|
# remove all buddies from activity
|
||||||
|
for buddy in self.get_buddies():
|
||||||
|
self.BuddyLeft(buddy._object_path)
|
||||||
|
self._buddies = {}
|
||||||
|
|
||||||
|
def get_buddies(self):
|
||||||
|
return self._buddies.values()
|
||||||
|
|
||||||
@dbus.service.signal(_ACTIVITY_INTERFACE, signature="o")
|
@dbus.service.signal(_ACTIVITY_INTERFACE, signature="o")
|
||||||
def BuddyJoined(self, buddy_path):
|
def BuddyJoined(self, buddy_path):
|
||||||
pass
|
pass
|
||||||
@ -67,14 +91,16 @@ class TestActivity(dbus.service.Object):
|
|||||||
def GetType(self):
|
def GetType(self):
|
||||||
return self._type
|
return self._type
|
||||||
|
|
||||||
@dbus.service.method(_ACTIVITY_INTERFACE,
|
@dbus.service.method(_ACTIVITY_INTERFACE)
|
||||||
async_callbacks=('async_cb', 'async_err_cb'))
|
def Join(self):
|
||||||
def Join(self, async_cb, async_err_cb):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
@dbus.service.method(_ACTIVITY_INTERFACE, out_signature="ao")
|
@dbus.service.method(_ACTIVITY_INTERFACE, out_signature="ao")
|
||||||
def GetJoinedBuddies(self):
|
def GetJoinedBuddies(self):
|
||||||
return []
|
ret = []
|
||||||
|
for buddy in self._buddies.values():
|
||||||
|
ret.append(dbus.ObjectPath(buddy._object_path))
|
||||||
|
return ret
|
||||||
|
|
||||||
@dbus.service.method(_ACTIVITY_INTERFACE, out_signature="soao")
|
@dbus.service.method(_ACTIVITY_INTERFACE, out_signature="soao")
|
||||||
def GetChannels(self):
|
def GetChannels(self):
|
||||||
@ -106,6 +132,26 @@ class TestBuddy(dbus.service.Object):
|
|||||||
self._object_path = _BUDDY_PATH + str(self._object_id)
|
self._object_path = _BUDDY_PATH + str(self._object_id)
|
||||||
dbus.service.Object.__init__(self, bus_name, self._object_path)
|
dbus.service.Object.__init__(self, bus_name, self._object_path)
|
||||||
|
|
||||||
|
def add_activity(self, activity):
|
||||||
|
if self._activities.has_key(activity._actid):
|
||||||
|
raise NotFoundError("Buddy already in activity")
|
||||||
|
self._activities[activity._actid] = activity
|
||||||
|
self.JoinedActivity(activity._object_path)
|
||||||
|
|
||||||
|
def remove_activity(self, activity):
|
||||||
|
if not self._activities.has_key(activity._actid):
|
||||||
|
raise NotFoundError("Buddy not in activity")
|
||||||
|
self.LeftActivity(activity._object_path)
|
||||||
|
del self._activities[activity._actid]
|
||||||
|
|
||||||
|
def leave_activities(self):
|
||||||
|
for activity in self.get_activities():
|
||||||
|
self.LeftActivity(activity._object_path)
|
||||||
|
self._activities = {}
|
||||||
|
|
||||||
|
def get_activities(self):
|
||||||
|
return self._activities.values()
|
||||||
|
|
||||||
@dbus.service.signal(_BUDDY_INTERFACE, signature="ay")
|
@dbus.service.signal(_BUDDY_INTERFACE, signature="ay")
|
||||||
def IconChanged(self, icon_data):
|
def IconChanged(self, icon_data):
|
||||||
pass
|
pass
|
||||||
@ -261,10 +307,22 @@ class TestPresenceService(dbus.service.Object):
|
|||||||
raise NotFoundError("The owner was not found.")
|
raise NotFoundError("The owner was not found.")
|
||||||
return dbus.ObjectPath(self._owner._object_path)
|
return dbus.ObjectPath(self._owner._object_path)
|
||||||
|
|
||||||
|
def _internal_share_activity(self, actid, atype, name, properties, color=None):
|
||||||
|
objid = self._get_next_object_id()
|
||||||
|
if not color:
|
||||||
|
color = self._owner._color
|
||||||
|
act = TestActivity(self._bus_name, objid, actid, name, color, atype, properties)
|
||||||
|
self._activities[actid] = act
|
||||||
|
self.ActivityAppeared(act._object_path)
|
||||||
|
return act
|
||||||
|
|
||||||
@dbus.service.method(_PRESENCE_INTERFACE, in_signature="sssa{sv}",
|
@dbus.service.method(_PRESENCE_INTERFACE, in_signature="sssa{sv}",
|
||||||
out_signature="o", async_callbacks=('async_cb', 'async_err_cb'))
|
out_signature="o")
|
||||||
def ShareActivity(self, actid, atype, name, properties, async_cb, async_err_cb):
|
def ShareActivity(self, actid, atype, name, properties):
|
||||||
pass
|
act = self._internal_share_activity(actid, atype, name, properties)
|
||||||
|
act.add_buddy(self._owner)
|
||||||
|
self._owner.add_activity(act)
|
||||||
|
return act._object_path
|
||||||
|
|
||||||
@dbus.service.method(_PRESENCE_INTERFACE, out_signature="so")
|
@dbus.service.method(_PRESENCE_INTERFACE, out_signature="so")
|
||||||
def GetPreferredConnection(self):
|
def GetPreferredConnection(self):
|
||||||
@ -285,21 +343,54 @@ class TestPresenceService(dbus.service.Object):
|
|||||||
if not self._buddies.has_key(pubkey):
|
if not self._buddies.has_key(pubkey):
|
||||||
raise NotFoundError("Buddy not found")
|
raise NotFoundError("Buddy not found")
|
||||||
buddy = self._buddies[pubkey]
|
buddy = self._buddies[pubkey]
|
||||||
|
activities = buddy.get_activities()
|
||||||
|
# remove activity from the buddy
|
||||||
|
buddy.leave_activities()
|
||||||
|
# remove the buddy from all activities
|
||||||
|
for act in activities:
|
||||||
|
act.remove_buddy(buddy)
|
||||||
self.BuddyDisappeared(buddy._object_path)
|
self.BuddyDisappeared(buddy._object_path)
|
||||||
del self._buddies[pubkey]
|
del self._buddies[pubkey]
|
||||||
|
|
||||||
@dbus.service.method(_PRESENCE_TEST_INTERFACE, in_signature="ssss")
|
@dbus.service.method(_PRESENCE_TEST_INTERFACE, in_signature="oo")
|
||||||
def AddActivity(self, actid, name, color, atype):
|
def AddBuddyToActivity(self, pubkey, actid):
|
||||||
objid = self._get_next_object_id()
|
pubkey = ''.join([chr(item) for item in pubkey])
|
||||||
act = TestActivity(self._bus_name, objid, actid, name, color, atype)
|
if not self._buddies.has_key(pubkey):
|
||||||
self._activities[actid] = act
|
raise NotFoundError("Buddy unknown")
|
||||||
self.ActivityAppeared(act._object_path)
|
if not self._activities.has_key(actid):
|
||||||
|
raise NotFoundError("Activity unknown")
|
||||||
|
|
||||||
|
buddy = self._buddies[pubkey]
|
||||||
|
activity = self._activities[actid]
|
||||||
|
activity.add_buddy(buddy)
|
||||||
|
buddy.add_activity(activity)
|
||||||
|
|
||||||
|
@dbus.service.method(_PRESENCE_TEST_INTERFACE, in_signature="oo")
|
||||||
|
def RemoveBuddyFromActivity(self, pubkey, actid):
|
||||||
|
pubkey = ''.join([chr(item) for item in pubkey])
|
||||||
|
if not self._buddies.has_key(pubkey):
|
||||||
|
raise NotFoundError("Buddy unknown")
|
||||||
|
if not self._activities.has_key(actid):
|
||||||
|
raise NotFoundError("Activity unknown")
|
||||||
|
|
||||||
|
buddy = self._buddies[pubkey]
|
||||||
|
activity = self._activities[actid]
|
||||||
|
buddy.remove_activity(activity)
|
||||||
|
activity.remove_buddy(buddy)
|
||||||
|
|
||||||
|
@dbus.service.method(_PRESENCE_TEST_INTERFACE, in_signature="ssssa{sv}")
|
||||||
|
def AddActivity(self, actid, name, color, atype, properties):
|
||||||
|
self._internal_share_activity(actid, atype, name, properties, color=color)
|
||||||
|
|
||||||
@dbus.service.method(_PRESENCE_TEST_INTERFACE, in_signature="s")
|
@dbus.service.method(_PRESENCE_TEST_INTERFACE, in_signature="s")
|
||||||
def RemoveActivity(self, actid):
|
def RemoveActivity(self, actid):
|
||||||
if not self._activities.has_key(actid):
|
if not self._activities.has_key(actid):
|
||||||
raise NotFoundError("Activity not found")
|
raise NotFoundError("Activity not found")
|
||||||
act = self._activities[actid]
|
act = self._activities[actid]
|
||||||
|
# remove activity from all buddies
|
||||||
|
for buddy in act.get_buddies():
|
||||||
|
buddy.remove_activity(act)
|
||||||
|
act.disappear()
|
||||||
self.ActivityDisappeared(act._object_path)
|
self.ActivityDisappeared(act._object_path)
|
||||||
del self._activities[actid]
|
del self._activities[actid]
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user