Use a custom scheme for app content
To get the origin right.
This commit is contained in:
parent
e649070aa2
commit
0abae0e7d0
@ -19,6 +19,7 @@ import json
|
|||||||
import os
|
import os
|
||||||
|
|
||||||
from gi.repository import GConf
|
from gi.repository import GConf
|
||||||
|
from gi.repository import Gio
|
||||||
from gi.repository import WebKit2
|
from gi.repository import WebKit2
|
||||||
from gwebsockets.server import Server
|
from gwebsockets.server import Server
|
||||||
|
|
||||||
@ -42,6 +43,9 @@ class HTMLActivity(activity.Activity):
|
|||||||
def __init__(self, handle):
|
def __init__(self, handle):
|
||||||
activity.Activity.__init__(self, handle)
|
activity.Activity.__init__(self, handle)
|
||||||
|
|
||||||
|
context = WebKit2.WebContext.get_default()
|
||||||
|
context.register_uri_scheme("activity", self._app_scheme_cb, None)
|
||||||
|
|
||||||
self._web_view = WebKit2.WebView()
|
self._web_view = WebKit2.WebView()
|
||||||
self.set_canvas(self._web_view)
|
self.set_canvas(self._web_view)
|
||||||
self._web_view.show()
|
self._web_view.show()
|
||||||
@ -54,12 +58,20 @@ class HTMLActivity(activity.Activity):
|
|||||||
|
|
||||||
index_path = os.path.join(activity.get_bundle_path(), "index.html")
|
index_path = os.path.join(activity.get_bundle_path(), "index.html")
|
||||||
self._key = os.urandom(16).encode("hex")
|
self._key = os.urandom(16).encode("hex")
|
||||||
self._web_view.load_uri("file://%s?port=%s&key=%s" %
|
self._web_view.load_uri("activity://%s/%s?port=%s&key=%s" %
|
||||||
(index_path, port, self._key))
|
(self.get_bundle_id(),
|
||||||
|
index_path,
|
||||||
|
port, self._key))
|
||||||
|
|
||||||
self._apis = {}
|
self._apis = {}
|
||||||
self._apis["activity"] = ActivityAPI(self)
|
self._apis["activity"] = ActivityAPI(self)
|
||||||
|
|
||||||
|
def _app_scheme_cb(self, request, user_data):
|
||||||
|
path = os.path.join(activity.get_bundle_path(), request.get_path())
|
||||||
|
|
||||||
|
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):
|
def _session_started_cb(self, server, session):
|
||||||
session.connect("message-received", self._message_received_cb)
|
session.connect("message-received", self._message_received_cb)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user