Get back mesh chat (for the everyone tab)

This commit is contained in:
Marco Pesenti Gritti
2006-06-21 23:49:37 -04:00
parent e956f22597
commit 974ef81c1e
5 changed files with 82 additions and 26 deletions
+26
View File
@@ -0,0 +1,26 @@
import logging
from sugar.chat.GroupChat import GroupChat
class ActivityChat(GroupChat):
SERVICE_TYPE = "_olpc_activity_chat._udp"
SERVICE_PORT = 6200
def __init__(self, activity):
GroupChat.__init__(self)
self._activity = activity
self._pservice.connect('service-appeared', self._service_appeared_cb)
self._pservice.track_service_type(ActivityChat.SERVICE_TYPE)
service = self._pservice.get_activity_service(activity, ActivityChat.SERVICE_TYPE)
if service is not None:
self._service_appeared_cb(self._pservice, None, service)
def _service_appeared_cb(self, pservice, buddy, service):
if service.get_activity_uid() == self._activity.get_id():
if service.get_type() == ActivityChat.SERVICE_TYPE:
logging.debug('Group chat service appeared, setup the stream.')
self._setup_stream(service)
def publish(self):
service = self._pservice.share_activity(self._activity,
stype = ActivityChat.SERVICE_TYPE, port = ActivityChat.SERVICE_PORT)
+5 -24
View File
@@ -2,34 +2,15 @@ import logging
from sugar.chat.Chat import Chat
from sugar.p2p.Stream import Stream
from sugar.presence.PresenceService import PresenceService
from sugar.presence.PresenceService import PresenceService
import sugar.env
class GroupChat(Chat):
SERVICE_TYPE = "_olpc_group_chat._udp"
SERVICE_PORT = 6200
def __init__(self, activity):
def __init__(self):
Chat.__init__(self)
self._chats = {}
self._activity = activity
self._pservice = PresenceService.get_instance()
self._pservice.start()
self._pservice.connect('service-appeared', self._service_appeared_cb)
self._pservice.track_service_type(GroupChat.SERVICE_TYPE)
service = self._pservice.get_activity_service(activity, GroupChat.SERVICE_TYPE)
if service is not None:
self._service_appeared_cb(self._pservice, None, service)
def _service_appeared_cb(self, pservice, buddy, service):
if service.get_activity_uid() == self._activity.get_id():
if service.get_type() == GroupChat.SERVICE_TYPE:
logging.debug('Group chat service appeared, setup the stream.')
self._setup_stream(service)
def publish(self):
service = self._pservice.share_activity(self._activity,
stype = GroupChat.SERVICE_TYPE, port = GroupChat.SERVICE_PORT)
self._pservice.start()
self._group_stream = None
def _setup_stream(self, service):
self._group_stream = Stream.new_from_service(service)
+36
View File
@@ -0,0 +1,36 @@
import logging
import random
from sugar.chat.GroupChat import GroupChat
from sugar.presence.Service import Service
import sugar.env
class MeshChat(GroupChat):
SERVICE_TYPE = "_olpc_mesh_chat._udp"
SERVICE_PORT = 6301
def __init__(self):
GroupChat.__init__(self)
self._pservice.connect('service-appeared', self._service_appeared_cb)
self._pservice.track_service_type(MeshChat.SERVICE_TYPE)
self._publish()
service = self._pservice.get_service(MeshChat.SERVICE_TYPE)
if service is not None:
self._service_appeared_cb(self._pservice, None, service)
def _service_appeared_cb(self, pservice, buddy, service):
if self._group_stream == None:
if service.get_type() == MeshChat.SERVICE_TYPE:
logging.debug('Mesh chat service appeared, setup the stream.')
self._setup_stream(service)
def _publish(self):
# Use random currently unassigned multicast address
address = "232.%d.%d.%d" % (random.randint(0, 254), random.randint(1, 254),
random.randint(1, 254))
service = Service(sugar.env.get_nick_name(), MeshChat.SERVICE_TYPE,
'local', address, MeshChat.SERVICE_PORT)
self._pservice.register_service(service)