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:
		
							parent
							
								
									b276f61da1
								
							
						
					
					
						commit
						3aadcbcbf0
					
				@ -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))
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user