sugar-toolkit-gtk3/sugar/p2p/model/LocalModel.py

60 lines
1.5 KiB
Python
Raw Normal View History

2006-05-15 20:48:08 +02:00
import socket
2006-06-18 04:06:40 +02:00
import logging
2006-05-15 20:48:08 +02:00
from sugar.p2p.Notifier import Notifier
2006-05-15 20:48:08 +02:00
from sugar.p2p.model.AbstractModel import AbstractModel
from sugar.p2p import network
class ModelRequestHandler(object):
def __init__(self, model):
self._model = model
def get_value(self, key):
return self._model.get_value(key)
def set_value(self, key, value):
return self._model.set_value(key, value)
class LocalModel(AbstractModel):
SERVICE_TYPE = "_olpc_model._tcp"
def __init__(self, activity, pservice, service):
2006-05-15 20:48:08 +02:00
AbstractModel.__init__(self)
2006-06-16 19:06:11 +02:00
self._pservice = pservice
self._activity = activity
self._service = service
2006-05-15 20:48:08 +02:00
self._values = {}
self._setup_service()
self._notifier = Notifier(service)
2006-05-15 20:48:08 +02:00
def get_value(self, key):
return self._values[key]
def set_value(self, key, value):
self._values[key] = value
self._notify_model_change(key)
self._notifier.notify(key)
2006-05-15 20:48:08 +02:00
def _setup_service(self):
service = self._pservice.share_activity(self._activity,
stype = LocalModel.SERVICE_TYPE,
address = '')
2006-05-15 20:48:08 +02:00
self._setup_server(service)
# FIXME this is duplicated with StreamReader
def _setup_server(self, service):
started = False
tries = 10
port = service.get_port()
while not started and tries > 0:
try:
2006-06-18 04:06:40 +02:00
logging.debug('Start model server on port %d' % (port))
2006-05-15 20:48:08 +02:00
p2p_server = network.GlibXMLRPCServer(("", port))
p2p_server.register_instance(ModelRequestHandler(self))
started = True
except(socket.error):
port = port + 1
tries = tries - 1
service.set_port(port)