mirror of
https://github.com/Feodor2/Mypal68.git
synced 2025-06-18 14:55:44 -04:00
14 KiB
14 KiB
Activity Stream Pings
The Activity Stream system add-on sends various types of pings to the backend (HTTPS POST) Onyx server :
- a
health
ping that reports whether or not a user has a custom about:home or about:newtab page - a
session
ping that describes the ending of an Activity Stream session (a new tab is closed or refreshed), and - an
event
ping that records specific data about individual user interactions while interacting with Activity Stream - a
performance
ping that records specific performance related events - an
undesired
ping that records data about bad app states and missing data - an
impression_stats
ping that records data about Pocket impressions and user interactions
Schema definitions/validations that can be used for tests can be found in system-addon/test/schemas/pings.js
.
Example Activity Stream health
log
{
"addon_version": "20180710100040",
"client_id": "374dc4d8-0cb2-4ac5-a3cf-c5a9bc3c602e",
"locale": "en-US",
"version": "62.0a1",
"release_channel": "nightly",
"event": "AS_ENABLED",
"value": 10,
// These fields are generated on the server
"date": "2016-03-07",
"ip": "10.192.171.13",
"ua": "python-requests/2.9.1",
"receive_at": 1457396660000
}
Example Activity Stream session
Log
{
// These fields are sent from the client
"action": "activity_stream_session",
"addon_version": "20180710100040",
"client_id": "374dc4d8-0cb2-4ac5-a3cf-c5a9bc3c602e",
"locale": "en-US",
"page": ["about:newtab" | "about:home" | "about:welcome" | "unknown"],
"session_duration": 1635,
"session_id": "{12dasd-213asda-213dkakj}",
"region": "US",
"profile_creation_date": 14786,
"user_prefs": 7
// These fields are generated on the server
"date": "2016-03-07",
"ip": "10.192.171.13",
"ua": "python-requests/2.9.1",
"receive_at": 1457396660000
}
Example Activity Stream user_event
Log
{
"action": "activity_stream_user_event",
"action_position": "3",
"addon_version": "20180710100040",
"client_id": "374dc4d8-0cb2-4ac5-a3cf-c5a9bc3c602e",
"event": "click or scroll or search or delete",
"locale": "en-US",
"page": ["about:newtab" | "about:home" | "about:welcome" | "unknown"],
"source": "top sites, or bookmarks, or...",
"session_id": "{12dasd-213asda-213dkakj}",
"recommender_type": "pocket-trending",
"metadata_source": "MetadataService or Local or TippyTopProvider",
"user_prefs": 7
// These fields are generated on the server
"ip": "10.192.171.13",
"ua": "python-requests/2.9.1",
"receive_at": 1457396660000,
"date": "2016-03-07",
}
Example Activity Stream performance
Log
{
"action": "activity_stream_performance_event",
"addon_version": "20180710100040",
"client_id": "374dc4d8-0cb2-4ac5-a3cf-c5a9bc3c602e",
"event": "previewCacheHit",
"event_id": "45f1912165ca4dfdb5c1c2337dbdc58f",
"locale": "en-US",
"page": "unknown", // all session-specific perf events should be part of the session perf object
"receive_at": 1457396660000,
"source": "TOP_FRECENT_SITES",
"value": 1,
"user_prefs": 7,
// These fields are generated on the server
"ip": "10.192.171.13",
"ua": "python-requests/2.9.1",
"receive_at": 1457396660000,
"date": "2016-03-07"
}
Example Activity Stream undesired event
Log
{
"action": "activity_stream_undesired_event",
"addon_version": "20180710100040",
"client_id": "26288a14-5cc4-d14f-ae0a-bb01ef45be9c",
"event": "MISSING_IMAGE",
"locale": "en-US",
"page": ["about:newtab" | "about:home" | "about:welcome" | "unknown"]
"source": "HIGHLIGHTS",
"value": 0,
"user_prefs": 7,
// These fields are generated on the server
"ip": "10.192.171.13",
"ua": "python-requests/2.9.1",
"receive_at": 1457396660000,
"date": "2016-03-07"
}
Example Activity Stream impression_stats
Logs
{
"action": "activity_stream_impression_stats",
"client_id": "n/a",
"session_id": "n/a",
"impression_id": "{005deed0-e3e4-4c02-a041-17405fd703f6}",
"addon_version": "20180710100040",
"locale": "en-US",
"source": "pocket",
"page": ["about:newtab" | "about:home" | "about:welcome" | "unknown"]
"tiles": [{"id": 10000}, {"id": 10001}, {"id": 10002}]
"user_prefs": 7
}
{
"action": "activity_stream_impression_stats",
"client_id": "n/a",
"session_id": "n/a",
"impression_id": "{005deed0-e3e4-4c02-a041-17405fd703f6}",
"addon_version": "20180710100040",
"locale": "en-US",
"source": "pocket",
"page": "unknown",
"user_prefs": 7,
// "pos" is the 0-based index to record the tile's position in the Pocket section.
// "shim" is a base64 encoded shim attached to spocs, unique to the impression from the Ad server.
"tiles": [{"id": 10000, "pos": 0, "shim": "enuYa1j73z3RzxgTexHNxYPC/b,9JT6w5KB0CRKYEU+"}],
// A 0-based index to record which tile in the "tiles" list that the user just interacted with.
"click|block|pocket": 0
}
Example Discovery Stream SPOCS Fill
log
{
// both "client_id" and "session_id" are set to "n/a" in this ping.
"client_id": "n/a",
"session_id": "n/a",
"impression_id": "{005deed0-e3e4-4c02-a041-17405fd703f6}",
"addon_version": "20180710100040",
"locale": "en-US",
"version": "68",
"release_channel": "release",
"spoc_fills": [
{"id": 10000, displayed: 0, reason: "frequency_cap", full_recalc: 1},
{"id": 10001, displayed: 0, reason: "blocked_by_user", full_recalc: 1},
{"id": 10002, displayed: 0, reason: "below_min_score", full_recalc: 1},
{"id": 10003, displayed: 0, reason: "campaign_duplicate", full_recalc: 1},
{"id": 10004, displayed: 0, reason: "probability_selection", full_recalc: 0},
{"id": 10004, displayed: 0, reason: "out_of_position", full_recalc: 0},
{"id": 10005, displayed: 1, reason: "n/a", full_recalc: 0}
]
}
Example Activity Stream Router
Pings
{
"client_id": "n/a",
"action": ["snippets_user_event" | "onboarding_user_event"],
"impression_id": "{005deed0-e3e4-4c02-a041-17405fd703f6}",
"source": "pocket",
"addon_version": "20180710100040",
"locale": "en-US",
"source": "NEWTAB_FOOTER_BAR",
"message_id": "some_snippet_id",
"event": "IMPRESSION"
}
KEY | DESCRIPTION | |
---|---|---|
action_position |
[Optional] The index of the element in the source that was clicked. |
1️⃣ |
action |
[Required] Either activity_stream_event , activity_stream_session , or activity_stream_performance . |
1️⃣ |
addon_version |
[Required] Firefox build ID, i.e. Services.appinfo.appBuildID . |
1️⃣ |
client_id |
[Required] An identifier for this client. | 1️⃣ |
card_type |
[Optional] ("bookmark", "pocket", "trending", "pinned", "search") | 1️⃣ |
search_vendor |
[Optional] the vendor of the search shortcut, one of ("google", "amazon", "wikipedia", "duckduckgo", "bing", etc.). This field only exists when card_type = "search" |
1️⃣ |
date |
[Auto populated by Onyx] The date in YYYY-MM-DD format. | 3️⃣ |
experiment_id |
[Optional] The unique identifier for a specific experiment. | 1️⃣ |
event_id |
[Required] An identifier shared by multiple performance pings that describe an entire request flow. | 1️⃣ |
event |
[Required] The type of event. Any user defined string ("click", "share", "delete", "more_items") | 1️⃣ |
highlight_type |
[Optional] Either ["bookmarks", "recommendation", "history"]. | 1️⃣ |
impression_id |
[Optional] The unique impression identifier for a specific client. | 1️⃣ |
ip |
[Auto populated by Onyx] The IP address of the client. | 2️⃣ |
locale |
[Auto populated by Onyx] The browser chrome's language (eg. en-US). | 2️⃣ |
load_trigger_ts |
[Optional][Server Counter][Server Alert for too many omissions] DOMHighResTimeStamp of the action perceived by the user to trigger the load of this page. | 1️⃣ |
load_trigger_type |
[Server Counter][Server Alert for too many omissions] Either ["first_window_opened", "menu_plus_or_keyboard", "unexpected"]. | 1️⃣ |
metadata_source |
[Optional] The source of which we computed metadata. Either (MetadataService or Local or TippyTopProvider ). |
1️⃣ |
page |
[Required] One of ["about:newtab", "about:home", "about:welcome", "unknown" (which either means not-applicable or is a bug)]. | 1️⃣ |
recommender_type |
[Optional] The type of recommendation that is being shown, if any. | 1️⃣ |
session_duration |
[Optional][Server Counter][Server Alert for too many omissions] Time in (integer) milliseconds of the difference between the new tab becoming visible | |
and losing focus. | 1️⃣ | |
session_id |
[Optional] The unique identifier for a specific session. | 1️⃣ |
source |
[Required] Either ("recent_links", "recent_bookmarks", "frecent_links", "top_sites", "spotlight", "sidebar") and indicates what action . |
2️⃣ |
received_at |
[Auto populated by Onyx] The time in ms since epoch. | 3️⃣ |
total_bookmarks |
[Optional] The total number of bookmarks in the user's places db. | 1️⃣ |
total_history_size |
[Optional] The number of history items currently in the user's places db. | 1️⃣ |
ua |
[Auto populated by Onyx] The user agent string. | 2️⃣ |
unload_reason |
[Required] The reason the Activity Stream page lost focus. | 1️⃣ |
url |
[Optional] The URL of the recommendation shown in one of the highlights spots, if any. | 1️⃣ |
value (performance) |
[Required] An integer that represents the measured performance value. Can store counts, times in milliseconds, and should always be a positive integer. | 1️⃣ |
value (event) |
[Optional] An object with keys "icon_type" and "card_type" to record the extra information for event ping | 1️⃣ |
ver |
[Auto populated by Onyx] The version of the Onyx API the ping was sent to. | 1️⃣ |
highlights_size |
[Optional] The size of the Highlights set. | 1️⃣ |
highlights_data_late_by_ms |
[Optional] Time in ms it took for Highlights to become initialized | 1️⃣ |
topsites_data_late_by_ms |
[Optional] Time in ms it took for TopSites to become initialized | 1️⃣ |
topstories.domain.affinity.calculation.ms |
[Optional] Time in ms it took for domain affinities to be calculated | 1️⃣ |
topsites_first_painted_ts |
[Optional][Service Counter][Server Alert for too many omissions] Timestamp of when the Top Sites element finished painting (possibly with only placeholder screenshots) | 1️⃣ |
custom_screenshot |
[Optional] Number of topsites that display a custom screenshot. | 1️⃣ |
screenshot_with_icon |
[Optional] Number of topsites that display a screenshot and a favicon. | 1️⃣ |
screenshot |
[Optional] Number of topsites that display only a screenshot. | 1️⃣ |
tippytop |
[Optional] Number of topsites that display a tippytop icon. | 1️⃣ |
rich_icon |
[Optional] Number of topsites that display a high quality favicon. | 1️⃣ |
no_image |
[Optional] Number of topsites that have no screenshot. | 1️⃣ |
topsites_pinned |
[Optional] Number of topsites that are pinned. | 1️⃣ |
topsites_search_shortcuts |
[Optional] Number of search shortcut topsites. | 1️⃣ |
visibility_event_rcvd_ts |
[Optional][Server Counter][Server Alert for too many omissions] DOMHighResTimeStamp of when the page itself receives an event that document.visibilityState == visible. | 1️⃣ |
tiles |
[Required] A list of tile objects for the Pocket articles. Each tile object mush have a ID, optionally a "pos" property to indicate the tile position, and optionally a "shim" property unique to the impression from the Ad server | 1️⃣ |
click |
[Optional] An integer to record the 0-based index when user clicks on a Pocket tile. | 1️⃣ |
block |
[Optional] An integer to record the 0-based index when user blocks a Pocket tile. | 1️⃣ |
pocket |
[Optional] An integer to record the 0-based index when user saves a Pocket tile to Pocket. | 1️⃣ |
user_prefs |
[Required] The encoded integer of user's preferences. | 1️⃣ & 4️⃣ |
is_preloaded |
[Required] A boolean to signify whether the page is preloaded or not | 1️⃣ |
icon_type |
[Optional] ("tippytop", "rich_icon", "screenshot_with_icon", "screenshot", "no_image") | 1️⃣ |
region |
[Optional] A string maps to pref "browser.search.region", which is essentially the two letter ISO 3166-1 country code populated by the Firefox search service. Note that: 1). it reports "OTHER" for those regions with smaller Firefox user base (less than 10000) so that users cannot be uniquely identified; 2). it reports "UNSET" if this pref is missing; 3). it reports "EMPTY" if the value of this pref is an empty string. | 1️⃣ |
profile_creation_date |
[Optional] An integer to record the age of the Firefox profile as the total number of days since the UNIX epoch. | 1️⃣ |
message_id |
[required] A string identifier of the message in Activity Stream Router. | 1️⃣ |
has_flow_params |
[required] One of [true, false]. A boolean identifier that indicates if Firefox Accounts flow parameters are set or unset. | 1️⃣ |
displayed |
[required] 1: a SPOC is displayed; 0: non-displayed | 1️⃣ |
reason |
[required] The reason if a SPOC is not displayed, "n/a" for the displayed, one of ("frequency_cap", "blocked_by_user", "campaign_duplicate", "probability_selection", "below_min_score", "out_of_position", "n/a") | 1️⃣ |
full_recalc |
[required] Is it a full SPOCS recalculation: 0: false; 1: true. Recalculation case: 1). fetch SPOCS from Pocket endpoint. Non-recalculation cases: 1). An impression updates the SPOCS; 2). Any action that triggers the selectLayoutRender |
1️⃣ |
Where:
1️⃣ Firefox data 2️⃣ HTTP protocol data 3️⃣ server augmented data 4️⃣ User preferences encoding table
Note: the following session-related fields are not yet implemented in the system-addon, but will likely be added in future versions:
{
"total_bookmarks": 19,
"total_history_size": 9,
"highlights_size": 20
}
This encoding mapping was defined in system-addon/lib/TelemetryFeed.jsm
Preference | Encoded value |
---|---|
showSearch |
1 |
showTopSites |
2 |
showTopStories |
4 |
showHighlights |
8 |
showSnippets |
16 |
showSponsored |
32 |
showCFRAddons |
64 |
showCFRFeatures |
128 |
Each item above could be combined with other items through bitwise OR operation