Merino

Merino is a service that provides address bar suggestions and curated recommendations to Firefox. Some of this content comes from third party providers. In this case, Merino serves as a privacy preserving buffer. User input in the address bar is handled by Merino and any clicked impression will be delegated to a Mozilla-controlled service which will then send an interaction ping if defined in the request and not to a provider directly. See API documentation for more details.

Table of Contents

api.md - API Documentation describes endpoints, query parameters, request and response headers, response objects and details on the suggestion objects.

firefox.md - Firefox and Merino Environments describes how to enable Merino in Firefox and lists the endpoints for the service in Production, State and Dev.

data.md - Data, Metrics, Logging describes all metrics and logs.

dev/index.md - Basic Developer Docs describes basics of working on Merino.

dev/dependencies.md - Development Dependencies describes the development dependencies required for Merino.

dev/logging-and-metrics.md - Logging and Metrics describes metrics, logging, and telemetry.

dev/release-process.md - Release Process describes the release process of Merino in detail.

dev/testing.md - Testing describes unit, integration and load tests for Merino.

dev/profiling.md - Profiling describes how to profile Merino to address performance issues.

operations/configs.md - Configuring Merino describes configuration management of the project, Dynaconf setup, and the configuration of the HTTP server, logging, metrics, Remote Settings, and Sentry.

operations/elasticsearch.md - Elasticsearch Operations describes some functionality and operations that we do on the Elasticsearch cluster.

operations/jobs.md - Merino Jobs describes the jobs that are configured in Merino. Indicate where the jobs exist and link to the details for how the jobs are run.

About the Name

This project drives an important part of Firefox's "felt experience". That is, the feeling of using Firefox, hopefully in a delightful way. The word "felt" in this phrase refers to feeling, but it can be punned to refer to the textile. Felt is often made of wool, and Merino wool (from Merino sheep) produces exceptionally smooth felt.

Architecture

Airflow (Merino Jobs)
Merino
Firefox
Middleware
Suggest Providers
Suggest Backends
Curated Recommendations Backends
New Tab
Url Bar
/api/v1/suggest
/api/v1/curated-recommendations
/api/v1/manifest
tries to query cache first
Syncs Wikipedia entries weekly
Accessing the Firefox URL bar
Wikipedia Sync
Top Picks Sync
Suggest Request Handler
Curated Recommendations Handler
Manifest Handler
MaxmindDB
Curated Recommendations Provider
Manifest Provider
Manifest Backend
corpus
corpus extended expiration
gcs engagement
fakespot
gcs prior
remote settings
accuweather
elastic
top picks
dynamic addons
adm
amo
geolocation
top-picks
weather
wikipedia
Geolocation
Logging
UserAgent
Metrics
Online Search and Suggest
Offline Search and Suggest
fetches adMarketplace, static Wikipedia,
and other suggestions.
Offline mode is fallback if Merino times out.
Curated Recommendations
Weather Widget
User
manifest
Addons API
Elasticsearch
GCS Top Picks Data,
a list of Mozilla curated popular sites and metadata to be
displayed on browser
Accuweather API
Redis Cache
GCS Merino Airflow Data
GCS Fakespot NewTab Products
Curated Corpus API
Remote Settings