2006-06-18 07:05:40 +02:00
|
|
|
import logging
|
|
|
|
|
2006-06-15 05:24:11 +02:00
|
|
|
from sugar.chat.Chat import Chat
|
2006-06-15 17:18:33 +02:00
|
|
|
from sugar.p2p.Stream import Stream
|
2006-06-22 05:49:37 +02:00
|
|
|
from sugar.presence.PresenceService import PresenceService
|
|
|
|
import sugar.env
|
2006-06-15 05:24:11 +02:00
|
|
|
|
|
|
|
class GroupChat(Chat):
|
2006-06-22 05:49:37 +02:00
|
|
|
def __init__(self):
|
2006-06-15 22:51:30 +02:00
|
|
|
Chat.__init__(self)
|
2006-06-18 07:05:40 +02:00
|
|
|
self._pservice = PresenceService.get_instance()
|
2006-06-22 05:49:37 +02:00
|
|
|
self._pservice.start()
|
|
|
|
self._group_stream = None
|
2006-06-15 05:24:11 +02:00
|
|
|
|
2006-06-18 07:05:40 +02:00
|
|
|
def _setup_stream(self, service):
|
|
|
|
self._group_stream = Stream.new_from_service(service)
|
2006-06-15 05:24:11 +02:00
|
|
|
self._group_stream.set_data_listener(self._group_recv_message)
|
|
|
|
self._stream_writer = self._group_stream.new_writer()
|
|
|
|
|
2006-06-18 09:00:23 +02:00
|
|
|
def _group_recv_message(self, address, msg):
|
|
|
|
pservice = PresenceService.get_instance()
|
2006-06-18 20:14:59 +02:00
|
|
|
[nick, msg] = self.deserialize_message(msg)
|
|
|
|
buddy = pservice.get_buddy_by_nick_name(nick)
|
2006-06-18 09:00:23 +02:00
|
|
|
if buddy:
|
|
|
|
self.recv_message(buddy, msg)
|
|
|
|
else:
|
2006-06-18 20:14:59 +02:00
|
|
|
logging.error('The buddy %s is not present.' % (nick))
|