Move the websocket service to the shell

It's a first step to make html activities much lighter. It also
just makes a lot more sense to have them interact directly with
the system rather than proxying through the python activity.
This commit is contained in:
Daniel Narvaez 2013-05-11 00:09:51 +02:00
parent b276f61da1
commit 3aadcbcbf0

View File

@ -15,31 +15,15 @@
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
import json
import os
from gi.repository import Gdk
from gi.repository import GConf
from gi.repository import Gio
from gi.repository import WebKit2
from gwebsockets.server import Server
from sugar3.activity import activity
class ActivityAPI:
def __init__(self, activity):
self._activity = activity
def get_xo_color(self):
client = GConf.Client.get_default()
color_string = client.get_string('/desktop/sugar/user/color')
return color_string.split(",")
def close(self):
self._activity.close()
class HTMLActivity(activity.Activity):
def __init__(self, handle):
activity.Activity.__init__(self, handle)
@ -58,26 +42,20 @@ class HTMLActivity(activity.Activity):
settings = self._web_view.get_settings()
settings.set_property("enable-developer-extras", True)
self._authenticated = False
self._server = Server()
self._server.connect("session-started", self._session_started_cb)
self._port = self._server.start()
self._key = os.urandom(16).encode("hex")
index_path = os.path.join(activity.get_bundle_path(), "index.html")
self._web_view.load_uri("activity://%s/%s" %
(self.get_bundle_id(), index_path))
self._apis = {}
self._apis["activity"] = ActivityAPI(self)
def _loading_changed_cb(self, web_view, load_event):
if load_event == WebKit2.LoadEvent.FINISHED:
key = os.environ["SUGAR_APISOCKET_KEY"]
port = os.environ["SUGAR_APISOCKET_PORT"]
script = "window.sugarKey = '%s'; " \
"window.sugarPort = %d; " \
"if (window.onSugarKeySet) " \
"window.onSugarKeySet();" % (self._key, self._port)
"window.sugarPort = '%s'; " \
"window.sugarId = '%s'; " \
"if (window.onSugarAuthSet) " \
"window.onSugarAuthSet();" % (key, port, self.get_id())
self._web_view.run_javascript(script, None, None, None)
@ -98,28 +76,3 @@ class HTMLActivity(activity.Activity):
request.finish(Gio.File.new_for_path(path).read(None),
-1, Gio.content_type_guess(path, None)[0])
def _session_started_cb(self, server, session):
session.connect("message-received", self._message_received_cb)
def _message_received_cb(self, session, message):
request = json.loads(message.data)
if request["method"] == "authenticate":
if self._key == request["params"][0]:
self._authenticated = True
return
if not self._authenticated:
return
api_name, method_name = request["method"].split(".")
method = getattr(self._apis[api_name], method_name)
result = method(*request["params"])
response = {"result": result,
"error": None,
"id": request["id"]}
session.send_message(json.dumps(response))