From 43a97878ce14b72f0981164f87f2e35e14151312 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 11:22:09 +0200 Subject: Adding upstream version 110.0.1. Signed-off-by: Daniel Baumann --- browser/components/extensions/parent/ext-search.js | 76 ++++++++++++++++++++++ 1 file changed, 76 insertions(+) create mode 100644 browser/components/extensions/parent/ext-search.js (limited to 'browser/components/extensions/parent/ext-search.js') diff --git a/browser/components/extensions/parent/ext-search.js b/browser/components/extensions/parent/ext-search.js new file mode 100644 index 0000000000..fe600ca900 --- /dev/null +++ b/browser/components/extensions/parent/ext-search.js @@ -0,0 +1,76 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +/* -*- Mode: indent-tabs-mode: nil; js-indent-level: 2 -*- */ +/* vim: set sts=2 sw=2 et tw=80: */ + +"use strict"; + +var { ExtensionError } = ExtensionUtils; + +this.search = class extends ExtensionAPI { + getAPI(context) { + return { + search: { + async get() { + await searchInitialized; + let visibleEngines = await Services.search.getVisibleEngines(); + let defaultEngine = await Services.search.getDefault(); + return Promise.all( + visibleEngines.map(async engine => { + let favIconUrl; + if (engine.iconURI) { + // Convert moz-extension:-URLs to data:-URLs to make sure that + // extensions can see icons from other extensions, even if they + // are not web-accessible. + // Also prevents leakage of extension UUIDs to other extensions.. + if ( + engine.iconURI.schemeIs("moz-extension") && + engine.iconURI.host !== context.extension.uuid + ) { + favIconUrl = await ExtensionUtils.makeDataURI( + engine.iconURI.spec + ); + } else { + favIconUrl = engine.iconURI.spec; + } + } + + return { + name: engine.name, + isDefault: engine.name === defaultEngine.name, + alias: engine.alias || undefined, + favIconUrl, + }; + }) + ); + }, + + async search(searchProperties) { + await searchInitialized; + let engine; + if (searchProperties.engine) { + engine = Services.search.getEngineByName(searchProperties.engine); + if (!engine) { + throw new ExtensionError( + `${searchProperties.engine} was not found` + ); + } + } + + const tab = searchProperties.tabId + ? tabTracker.getTab(searchProperties.tabId) + : null; + + await windowTracker.topWindow.BrowserSearch.loadSearchFromExtension( + searchProperties.query, + engine, + tab, + context.principal + ); + }, + }, + }; + } +}; -- cgit v1.2.3