[epiphany/pgriffis/web-extension-beastify: 5/5] WebExtension: Support accessing resources from web
- From: Patrick Griffis <pgriffis src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [epiphany/pgriffis/web-extension-beastify: 5/5] WebExtension: Support accessing resources from web
- Date: Sat, 21 May 2022 00:52:43 +0000 (UTC)
commit 58d2d79b15e4593076bd42e169745680980cbee0
Author: Patrick Griffis <pgriffis igalia com>
Date: Fri May 20 13:44:36 2022 -0500
WebExtension: Support accessing resources from web
This isn't done yet but was the first step.
src/webextension/ephy-web-extension-manager.c | 46 +++++++++++++++++++++++++++
1 file changed, 46 insertions(+)
---
diff --git a/src/webextension/ephy-web-extension-manager.c b/src/webextension/ephy-web-extension-manager.c
index 3b5e2eacc..a307fff26 100644
--- a/src/webextension/ephy-web-extension-manager.c
+++ b/src/webextension/ephy-web-extension-manager.c
@@ -149,6 +149,44 @@ ephy_web_extension_manager_scan_directory (EphyWebExtensionManager *self,
}
}
+static void
+main_context_web_extension_scheme_cb (WebKitURISchemeRequest *request,
+ gpointer user_data)
+{
+ EphyWebExtensionManager *self = EPHY_WEB_EXTENSION_MANAGER (user_data);
+ EphyWebExtension *web_extension = NULL;
+ const char *path;
+ const unsigned char *data;
+ gsize length;
+ g_autoptr (GInputStream) stream = NULL;
+ g_auto (GStrv) split = NULL;
+
+ path = webkit_uri_scheme_request_get_uri (request) + strlen ("ephy-webextension://");
+
+ split = g_strsplit (path, "/", -1);
+ for (GList *list = self->web_extensions; list && list->data; list = list->next) {
+ EphyWebExtension *ext = EPHY_WEB_EXTENSION (list->data);
+
+ if (strcmp (ephy_web_extension_get_guid (ext), split[0]) == 0) {
+ web_extension = EPHY_WEB_EXTENSION (list->data);
+ break;
+ }
+ }
+
+ if (!web_extension)
+ return;
+
+ /* FIXME: This needs to be filtered by the extension manifest's "web_accessible_resources"
+ * property which involves some pattern matching. */
+
+ data = ephy_web_extension_get_resource (web_extension, path + strlen (split[0]) + 1, &length);
+ if (!data)
+ return;
+
+ stream = g_memory_input_stream_new_from_data (data, length, NULL);
+ webkit_uri_scheme_request_finish (request, stream, length, NULL);
+}
+
static void
ephy_web_extension_manager_constructed (GObject *object)
{
@@ -192,6 +230,13 @@ ephy_web_extension_manager_class_init (EphyWebExtensionManagerClass *klass)
static void
ephy_web_extension_manager_init (EphyWebExtensionManager *self)
{
+ WebKitWebContext *web_context;
+
+ web_context = ephy_embed_shell_get_web_context (ephy_embed_shell_get_default ());
+ webkit_web_context_register_uri_scheme (web_context, "ephy-webextension",
main_context_web_extension_scheme_cb, self, NULL);
+ webkit_security_manager_register_uri_scheme_as_secure (webkit_web_context_get_security_manager
(web_context),
+ "ephy-webextension");
+
}
EphyWebExtensionManager *
@@ -595,6 +640,7 @@ web_extension_cb (WebKitURISchemeRequest *request,
g_autoptr (GInputStream) stream = NULL;
g_autoptr (GError) error = NULL;
+ /* FIXME: For paths on different hosts we should support web_accessible_resources. */
path = webkit_uri_scheme_request_get_path (request);
/* FIXME: This may be the place to handle predefined messages and localized CSS:
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]