Here is a quick overview of the most important code parts. They can be found in the telemetry folder.
TelemetryController: Main telemetry logic, e.g. assembling pings, local storage (when archiving is enabled), preference changes, testing
Telemetry.cpp contains most of the public interface, implements the IDL
The different data types for telemetry are handled in TelemetryHistogram, TelemetryScalar, TelemetryEvent.
TelemetryEnvironment: A helper for gathering environment data, like build version or graphics data
TelemetryScheduler: Starts regular jobs for collecting and sending data
TelemetrySend: Sending and caching of pings
TelemetryStorage: Handles writing pings to disk for TelemetrySend
TelemetrySession: Collects data for a browsing session, includes many of the most important probes (aka metrics)
Policy: A layer of indirection added to provide testability. A common pattern in many files
pings/: Contains definitions and handling for most ping types, like EventPing or PrioPing
More details on different topics can be found in these chapters: