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

53 lines
1.4 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):
self._service = self._pservice.share_activity(
self._activity, stype = LocalModel.SERVICE_TYPE)
self._setup_server(self._service)
2006-05-15 20:48:08 +02:00
# FIXME this is duplicated with StreamReader
def _setup_server(self, service):
port = service.get_port()
2006-07-26 02:04:15 +02:00
logging.debug('Start model server on port %d' % (port))
p2p_server = network.GlibXMLRPCServer(("", port))
p2p_server.register_instance(ModelRequestHandler(self))
def shutdown(self):
self._pservice.unregister_service(self._service)