summaryrefslogtreecommitdiffstats
path: root/toolkit/components/search/docs/SearchServiceHighlevelOverview.rst
blob: 1701f3a52b704710b6e307eb404851320c4a8379 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
=================================
SearchService High-level Overview
=================================
``SearchService`` is the core component that manages Search Engines on the
Firefox browser.

The following diagram is a high level systems context diagram of the
``SearchService``. The diagram illustrates which systems interface with the
``SearchService`` so that it can do its job of managing the Search Engines.

The diagram and description is an over-simplification of the ``SearchService's``
responsibilities. It specifically highlights how the ``SearchService`` serves
search engines to the browser on startup. However, the ``SearchService`` has
many other responsibilities that are not outlined in the diagram such as
maintaining and managing the Search Engines when various items change, e.g. the
user's region or locale, configuration changes received from remote settings,
updates received to search engine data. Nonetheless, the diagram gives a broad
overview of the main components the ``SearchService`` interacts with most often.

Diagram
=======
.. figure:: assets/search-service-diagram.png
   :scale: 85%
   :align: center

Description of the Diagram
==========================
These steps follow the same number on the diagram. Number 1 on the diagram is
described by number 1 below.

1. When the user opens the Firefox Browser, the code starts to build the browser
   UI components. During this startup phase, we have various systems making
   calls to the ``SearchService``. E.g. `browser.js <https://searchfox.org/mozilla-central/rev/cb6f8d7b1f1782b9d4b2ee7312de1dcc284aaf06/browser/base/content/browser.js#3797>`_
   calls ``Services.search.getDefault`` to fetch the default Search Engine.

2. The ``SearchService`` needs information from ``System Add-ons``,
   ``SearchSettings``, and ``Remote Settings`` to build the correct engines in
   the right order and to return the list of engines to its callers.

   a) First, the ``SearchService`` makes a request for the search configuration.
   ``SearchService`` calls `SearchEngineSelector.fetchEngineConfiguration <https://searchfox.org/mozilla-central/rev/cb6f8d7b1f1782b9d4b2ee7312de1dcc284aaf06/toolkit/components/search/SearchService.sys.mjs#2247>`_
   which makes a call to `Remote Settings <https://searchfox.org/mozilla-central/rev/cb6f8d7b1f1782b9d4b2ee7312de1dcc284aaf06/toolkit/components/search/SearchEngineSelector.sys.mjs#129>`_
   for the search configuration. Remote Settings does not fetch the search
   configuration from the remote database on startup. Instead Remote Settings
   tries to load the :searchfox:`search configuration dump file <services/settings/dumps/main/search-config.json>`
   from its local database and if that is empty, it will load the dump file into
   its local database. Only after startup will Remote Settings connect to the
   remote database when necessary. By connecting after startup, it avoids
   a potential network request that could delay startup.

   b) Second, the ``SearchService`` `fetches a JSON file <https://searchfox.org/mozilla-central/rev/cb6f8d7b1f1782b9d4b2ee7312de1dcc284aaf06/toolkit/components/search/SearchService.sys.mjs#1296-1297>`_
   from the `SearchSettings <https://searchfox.org/mozilla-central/source/toolkit/components/search/SearchSettings.sys.mjs>`_.
   This JSON file contains Search Engine metadata that is saved on the user's
   computer. It's information that helps the ``SearchService`` remember the
   user's custom settings for the Search Engines.

   c) Third, the `System Add-ons <https://searchfox.org/mozilla-central/rev/cb6f8d7b1f1782b9d4b2ee7312de1dcc284aaf06/browser/components/extensions/parent/ext-chrome-settings-overrides.js#536>`_
   passes the extension data to the ``SearchService``. At this point, the
   ``SearchService`` only installs user installed search extensions. For the
   Application Provided engines we create those when ``SearchService`` calls `_makeEngineFromConfig <https://searchfox.org/mozilla-central/rev/3002762e41363de8ee9ca80196d55e79651bcb6b/toolkit/components/search/SearchService.sys.mjs#3421-3440>`_.
   Then ``_makeEngineFromConfig`` will create a new ``AddonSearchEngine``.
   When the `AddonSearchEngine.init <https://searchfox.org/mozilla-central/rev/3002762e41363de8ee9ca80196d55e79651bcb6b/toolkit/components/search/AddonSearchEngine.sys.mjs#83-87,89>`_
   method is called, it combines both the extension and search configuration
   data to create the correct engine for the user based on locale, region and
   other information.

   After steps 2a, 2b, and 2c the ``SearchService`` has finished gathering
   search engine data from ``System Add-ons``, ``SearchSettings``, and
   ``Remote Settings``. Now the ``SearchService`` can build the different
   types of Search Engines.

3. The ``SearchService`` creates new instances of :searchfox:`SearchEngines <toolkit/components/search/SearchEngine.sys.mjs>`
   by making an `Add-on, Open Search, or Enterprise Policy Search Engine <https://firefox-source-docs.mozilla.org/toolkit/search/SearchEngines.html>`_.

4. The ``SearchService`` returns the engines to the caller that requested it.
   E.g. the ``SearchService`` passes the default Search Engine back to
   ``browser.js``, the system that initially requested it.

Updates
=======
This page is up to date as of March 10, 2023. If the diagram or description
becomes out of date, please find access to the
``Search Service Diagram`` through the ``Firefox Search > Search Service
Documentation`` folder in the shared drive or through this link `here <https://drive.google.com/file/d/1vKRRK87kIGt6xamHJuclkC04EKrS69Qw/view?usp=sharing>`_.
Contributions are welcomed to keep this page up to date.