- #1971: Bumped
glean_parser
version to14.5.0
. - #1970: Add
window.Glean.debugSession
API for automatically opening a link to the Debug Ping Viewer with your current session selected.
- #1935: BREAKING CHANGE: Remove
migrateFromLegacyStorage
capability and configuration option. If your project currently sets themigrateFromLegacyStorage
value, this will no longer work. - #1942: Bumped
glean_parser
version to14.1.2
.
- #1923: Bumped
glean_parser
version to14.0.1
. - #1921: BUGFIX: Fix issue causing
glean.client.annotation.experimentation_id
metric to not get added in certain pings. - #1919: Add
glean.page_id
to Glean automatic events.
This is the official release based on the v5.0.0-pre.0 release.
- #1895: Improve automatic click events for nested elements.
- #1899: Bug 1886113 - Add wall-clock timestamps to all events.
- #1900: Bug 1886443 - automatic click events in web sample project.
- #1866: Added a new uploader that falls back to
fetch
ifnavigator.sendBeacon
fails. - #1876: BREAKING CHANGE:
navigator.sendBeacon
with fallback tofetch
(see #1866) is now the default uploader. This can be changed manually. - #1850: Automatically record basic session information (
session_id
&session_count
) for web properties.
- This is the official release based on the v4.0.0-pre.x releases.
- #1848: Support for automatically collecting element click events (first version)
- #1849: Truncate event extra strings to 500 bytes. This also updates other string-based metrics to truncate based on max bytes rather than a set number of characters.
- #1835: Added support for automatic page load instrumentation.
- #1846: Add logging messages when using the debugging APIs from the browser console.
- #1834: Added support for
navigator.sendBeacon
. This is not turned on by default and needs to be enabled manually.
- #1808: BREAKING CHANGE: Make glean.js fully synchronous.
- #1835: Automatic instrumentation of page load events for simple web properties.
This is the official release based on v3.0.0-pre.1.
- #1814: BREAKING CHANGE: Temporarily drop support for web extensions. This platform will be added again once we complete the Glean.js platform refactoring.
- #1788: Fix
window
is undefined error when setting up browser debugging.
- #1772: Fix bug where
window.Glean
functions were getting set on non-browser properties. - #1784: Store
window.Glean
debugging values insessionStorage
. This will set debug options on page init while the current session is still active.
- #1770: Allow debugging in browser console via
window.Glean
.
- #1768: Add support for
GLEAN_PYTHON
andGLEAN_PIP
environment variables. - #1755: Add sync check to
set
function for the URL metric. - #1766: Update default
maxEvents
count to 1. This means an events ping will be sent after each recorded event unless themaxEvents
count is explicitly set to a larger number.
- #1751: Add a migration flag to initialize. If not explicitly set in the
config
object the migration from IndexedDB to LocalStorage will not occur. The only projects that should ever set this flag are those that have used Glean.js in production with a version <v2.0.0 and have upgraded.
Important
This version of Glean.js migrates the browser implementation from using IndexedDB to using LocalStorage. The storage change means that all Glean.js actions run synchronously.
- #1748: Update glean_parser version to the latest.
- #1733: Add SSR support for Glean.js.
- #1728: Migrate client_id and first_run_date.
- #1695: Update Glean.js web to use LocalStorage.
- #1544: Upgrade
glean_parser
version to6.2.1
. - #1516: Implement the Custom Distribution metric type.
- #1514: Implement the Memory Distribution metric type.
- #1475: Implement the Timing Distribution metric type.
- #1513: Bump URL metric character limit to 8k to support longer URLs. URLs that are too long now are truncated to
URL_MAX_LENGTH
and still recorded along with an Overflow error. - #1500: BUGFIX: Update how we invoke CLI python script to fix
npm run glean
behavior on Windows. - #1457: Update
ts-node
to 10.8.0 to resolve ESM issues when running tests inside ofwebext
sample project. - #1452: Remove
glean.restarted
trailing events from events list. - #1450: Update
ts-node
to 10.8.0 to resolve ESM issues when running tests. - #1449: BUGFIX: Add missing quotes to
prepare-release
script to fix issues with version numbers in Qt sample README & circle ci config. - #1449: Update Qt sample project docs to include note about problems with different version numbers of Qt commands.
- #1318: Expose
ErrorType
through its own entry point. - #1271: BUGFIX: Fix pings validation function when scanning pings database on initialize.
- This bug was preventing pings that contained custom headers from being successfully validated and enqueued on initialize.
- #1335: BUGFIX: Fix uploading gzip-compressed pings in Node.
- #1415: BUGFIX: Publish the TS type information for the
web
platform.
- #1154: BUGFIX: Implemented initialize and set_upload_enabled reasons for deletion-request ping.
- #1233: Add optional
buildDate
argument toinitialize
configuration. The build date can be generated by glean_parser. - #1233: Update glean_parser to version 5.1.0.
- #1217: Record
InvalidType
error when incorrectly type values are passed to metric recording functions. - #1267: Implement the 'events' ping.
- #1220: Refactor virtual environment behavior to support virtual environments that aren't in the project root.
- #1130: BUGFIX: Guarantee event timestamps
cannot be negative numbers.
- Timestamps were observed to be negative in a few occurrences, for platforms that do not provide the
performance.now
API, namely QML, and in which we fallback to theDate.now
API. - If event timestamps are negative pings are rejected by the pipeline.
- Timestamps were observed to be negative in a few occurrences, for platforms that do not provide the
- #1132: Retry ping request on network error with
keepalive: false
. This is sometimes an issue on Chrome browsers below v81. - #1170: Update glean_parser to version 5.0.0.
- #1178: Enable running the
glean
command offline.- When offline Glean will not attempt to install glean_parser.
- #1178: Enable running the
glean
command with as many or as little arguments as wanted.- Previously the command could only be run with 3 commands, even though all glean_parser commands would have been valid commands for the
glean
CLI.
- Previously the command could only be run with 3 commands, even though all glean_parser commands would have been valid commands for the
- #1210: Show comprehensive error message when missing
storage
permissions for Glean on web extensions. - #1223: Add
--glean-parser-version
command to CLI to allow users to retrieve the glean_parser version without installing glean_parser. - #1228: BUGFIX: Apply debug features before sending pings at initialize.
- #1065: Delete minimal amount of data when invalid data is found while collecting ping.
- Previous behavior was to delete the whole ping when invalid data was found on the database, new behavior only deletes the actually invalid data and leave the rest of the ping intact.
- #1065: Only import metric types into the library when they are used either by the user or Glean itself.
- Previously the code required to deserialize metric data from the database was always imported by the library even if the metric type was never used by the client. This effort will decrease the size of the Glean.js bundles that don't import all the metric types.
- #1046: Remove legacy X-Client-Type X-Client-Version from Glean pings.
- #1071: BREAKING CHANGE: Move the
testResetGlean
API from the Glean singleton and into it's own entry point@mozilla/glean/testing
.- In order to use this API one must import it through
import { testResetGlean } from "@mozilla/glean/testing"
instead of using it from the Glean singleton directly. - This lower the size of the Glean library, because testing functionality is not imported unless in a testing environment.
- This change does not apply to QML. In this environment the API remains the same.
- In order to use this API one must import it through
- #1045: BUGFIX: Provide informative error message when unable to access database in QML.
- #1077: BUGFIX: Do not clear lifetime metrics before submitting
deletion-request
ping on initialize.- This bug causes malformed
deletion-request
pings in Glean is initialized withuploadEnabled=false
.
- This bug causes malformed
- #1006: Implement the rate metric.
- #1066: BUGFIX: Guarantee reported timestamps are never floating point numbers.
- Floating point timestamps are rejected by the pipeline.
- #984: BUGFIX: Return correct upload result in case an error happens while building a ping request.
- #988: BUGFIX: Enforce rate limitation at upload time, not at ping submission time.
- Note: This change required a big refactoring of the internal uploading logic.
- #994: Automatically restart ping upload once the rate limit window is ended.
- Prior to this change, ping uploading would only be resumed once the
.submit()
API was called again, even if Glean was not throttled anymore. - Note: this change does not apply to QML. We used the
setTimeout
/clearTimeout
APIs in this feature and those are not available on the QML platform. Follow Bug 1743140 for updates.
- Prior to this change, ping uploading would only be resumed once the
- #1015: BUGFIX: Make attempting to call the
setUploadEnabled
API before initializing Glean a no-op. - #1016: BUGFIX: Make shutdown a no-op in case Glean is not initialized.
- #981: Update rate limits for ping submission from 15 pings/minute to 40 pings/minute.
- #967: BREAKING CHANGE: Remove
debug
option from Glean configuration option.- The
Glean.setDebugViewTag
,Glean.setSourceTags
andGlean.setLogPings
should be used instead. Note that these APIs can safely be called prior to initialization.
- The
- #965: Attempt to infer the Python virtualenv folder from the environment before falling back to the default
.venv
.- Users may provide a folder name through the
VIRTUAL_ENV
environment variable. - If the user is inside an active virtualenv the
VIRTUAL_ENV
environment variable is already set by Python. See: https://docs.python.org/3/library/venv.html.
- Users may provide a folder name through the
- #968: Add runtime arguments type checking to
Glean.setUploadEnabled
API. - #970: BUGFIX: Guarantee uploading is immediately resumed if the uploader has been stopped due to any of the uploading limits being hit.
- #924: Only HTTPS server endpoints outside of testing mode.
- In testing mode HTTP may be used. No other protocols are allowed.
- #951: Expose Uploader, UploadResult and UploadResultStatus.
- These are necessary for creating custom uploaders. Especially from TypeScript.
- #856: Expose the
@mozilla/glean/web
entry point for using Glean.js in websites. - #856: Implement the
PlatformInfo
module for the web platform.- Out of
os
,os_version
,architecture
andlocale
, on the web platform, we can only retrieveos
andlocale
information. The other information will default to the known valueUnknown
for all pings coming from this platform.
- Out of
- #856: Expose the
@mozilla/glean/web
entry point for using Glean.js in websites. - #908: BUGFIX: Guarantee internal
uploadEnabled
state always has a value.- When
uploadEnabled
was set tofalse
and then Glean was restarted with it stillfalse
, the internaluploadEnabled
state was not being set. That should not cause particularly harmful behavior, sinceundefined
is still a "falsy" value. However, this would create a stream of loud and annoying log messages.
- When
- #898: Implement the
Storage
module for the web platform.
- #755: Only allow calling of
test*
functions in "test mode".- Glean is put in "test mode" once the
Glean.testResetGlean
API called.
- Glean is put in "test mode" once the
- #811: Apply various fixes to the Qt entry point file.
- Expose
ErrorType
. This is only useful for testing purposes; - Fix version of
QtQuick.LocalStorage
plugin; - Fix the way to access the lib from inside the
shutdown
method. Previous to this fix, it is not possible to use theshutdown
method; - Expose the
Glean.testRestGlean
API.
- Expose
- #822: Fix API reference docs build step.
- #825: Accept
architecture
andosVersion
as initialization parameters in Qt. In Qt these values are not easily available from the environment.
- #796: Support setting the
app_channel
metric.- As described in "Release channels".
- #799: Make sure Glean does not do anything else in case initialization errors.
- This may happen in case there is an error creating the databases. Mostly an issue on Qt/QML where we use a SQLite database which can throw errors on initialization.
- #799: Provide stack traces when logging errors.
- #780: Fix the publishing step for releases. The Qt-specific build should now publish correctly.
-
#754: Change target ECMAScript target from 2015 to 2016 when building for Qt.
-
#779: Add a number of workarounds for the Qt JavaScript engine.
-
#775: Disallow calling test only methods outside of test mode.
- NOTE: Test mode is set once the API
Glean.testResetGlean
is called.
- NOTE: Test mode is set once the API
- #696: Expose Node.js entry point
@mozilla/glean/node
. - #695: Implement PlatformInfo module for the Node.js platform.
- #695: Implement Uploader module for the Node.js platform.
- #526: Implement mechanism to sort events reliably throughout restarts.
- A new event (
glean.restarted
) will be included in the events payload of pings, in case there was a restart in the middle of the ping measurement window.
- A new event (
- #534: Expose
Uploader
base class through@mozilla/glean/<platform>/uploader
entry point. - #580: Limit size of pings database to 250 pings or 10MB.
- #580: BUGFIX: Pending pings at startup up are uploaded from oldest to newest.
- #607: Record an error when incoherent timestamps are calculated for events after a restart.
- #630: Accept booleans and numbers as event extras.
- #647: Implement the Text metric type.
- #658: Implement rate limiting for ping upload.
- Only up to 15 ping submissions every 60 seconds are now allowed.
- #658: BUGFIX: Unblock ping uploading jobs after the maximum of upload failures are hit for a given uploading window.
- #661: Include unminified version of library on Qt/QML builds.
- #681: BUGFIX: Fix error in scanning events database upon initialization on Qt/QML.
- This bug prevents the changes introduced in #526 from working properly in Qt/QML.
- #692: BUGFIX: Ensure events database is initialized at a time Glean is already able to record metrics.
- This bug also prevents the changes introduced in #526 from working properly in all platforms.
- #552: BUGFIX: Do not clear
deletion-request
ping from upload queue when disabling upload.
- #542: Implement
shutdown
API.
-
#529: Implement the URL metric type.
-
#526: Implement new events sorting logic, which allows for reliable sorting of events throughout restarts.
- #346: Provide default HTTP client for Qt/QML platform.
- #399: Check if there are ping data before attempting to delete it.
- This change lowers the amount of log messages related to attempting to delete nonexistent data.
- #411: Tag all messages logged by Glean with the component they are coming from.
- #415, #430: Gzip ping payload before upload
- This changes the signature of
Uploader.post
to acceptstring | Uint8Array
for thebody
parameter, instead of onlystring
.
- This changes the signature of
- #431: BUGFIX: Record the timestamp for events before dispatching to the internal task queue.
- #462: Implement persistent storage for Qt/QML platform.
- #466: Expose
ErrorType
enum, for using with thetestGetNumRecordedErrors
API. - #497: Implement limit of 1MB for ping request payload. Limit is calculated after gzip compression.
- #389: BUGFIX: Make sure to submit a
deletion-request
ping before clearing data when toggling upload. - #375: Release Glean.js for Qt as a QML module.
- #342: BUGFIX: Fix timespan payload representation to match exactly the payload expected according to the Glean schema.
- #343: BUGFIX: Report the correct failure exit code when the Glean command line tool fails.
- #313: Send Glean.js version and platform information on X-Telemetry-Agent header instead of User-Agent header.
- #313: Implement error recording mechanism and error checking testing API.
- #319: BUGFIX: Do not allow recording floats with the quantity and counter metric types.
- #279: BUGFIX: Ensure only empty pings triggers logging of "empty ping" messages.
- #288: Support collecting
PlatformInfo
fromQt
applications. Only OS name and locale are supported. - #281: Add the QuantityMetricType.
- #303: Implement setRawNanos API for the TimespanMetricType.
- #260: Set minimum node (>= 12.0.0) and npm (>= 7.0.0) versions.
- #202: Add a testing API for the ping type.
- #253:
- Implement the timespan metric type.
- BUGFIX: Report event timestamps in milliseconds.
- #261: Show a spinner while setting up python virtual environment
- #273: BUGFIX: Expose the missing
LabeledMetricType
andTimespanMetricType
in Qt.
- #256: BUGFIX: Add the missing
js
extension to the dispatcher.
- #254: BUGFIX: Allow the usage of the Glean specific metrics API before Glean is initialized.
- #228: Provide a Qt build with every new release.
- #227: BUGFIX: Fix a bug that prevented using
labeled_string
andlabeled_boolean
. - #226: BUGFIX: Fix Qt build configuration to target ES5.
- #220: Update
glean_parser
to version 3.1.1.
- #219: BUGFIX: Fix path to ping entry point in package.json.
- #201: BUGFIX: Do not let the platform be changed after Glean is initialized.
- #215: Update the
glean-parser
to version 3.1.0. - #214: Improve error reporting of the Glean command.
- #206: BUGFIX: Fix ping URL path.
- Application ID was being reporting as
undefined
.
- Application ID was being reporting as
- #173: Drop Node.js support from webext entry points
- #155: Allow to define custom uploaders in the configuration.
- #184: Correctly report
appBuild
andappDisplayVersion
if provided by the user. - #198, #192, #184, #180, #174, #165: BUGFIX: Remove all circular dependencies.
- #143: Provide a way to initialize and reset Glean.js in tests.
- #130: BUGFIX: Fix destination path of CommonJS' build
package.json
.
- #123: BUGFIX: Fix support for ES6 environments.
- Include
.js
extensions in all local import statements.- ES6' module resolution algorithm does not currently support automatic resolution of file extensions and does not have the ability to import directories that have an index file. The extension and the name of the file being import need to always be specified. See: https://nodejs.org/api/esm.html#esm_customizing_esm_specifier_resolution_algorithm
- Add a
type: module
declaration to the mainpackage.json
.- Without this statement, ES6 support is disabled. See: https://nodejs.org/docs/latest-v13.x/api/esm.html#esm_enabling.:
- To keep support for CommonJS, in our CommonJS build we include a
package.json
that overrides thetype: module
of the mainpackage.json
with atype: commonjs
.
- Include
- #96: Provide a ping encryption plugin.
- This plugin listens to the
afterPingCollection
event. It receives the collected payload of a ping and returns an encrypted version of it using a JWK provided upon instantiation.
- This plugin listens to the
- #95: Add a
plugins
property to the configuration options and create an event abstraction for triggering internal Glean events.- The only internal event triggered at this point is the
afterPingCollection
event, which is triggered after ping collection and logging, and before ping storing. - Plugins are built to listen to a specific Glean event. Each plugin must define an
action
, which is executed every time the event they are listening to is triggered.
- The only internal event triggered at this point is the
- #101: BUGFIX: Only validate Debug View Tag and Source Tags when they are present.
- #102: BUGFIX: Include a Glean User-Agent header in all pings.
- #97: Add support for labeled metric types (string, boolean and counter).
- #105: Introduce and publish the
glean
command for using theglean-parser
in a virtual environment.
- #92: Remove
web-ext-types
frompeerDependencies
list. - #98: Add external APIs for setting the Debug View Tag and Source Tags.
- #99: BUGFIX: Add a default ping value in the testing APIs.
- #90: Provide exports for CommonJS and browser environments.
- #90: BUGFIX: Accept lifetimes as strings when instantiating metric types.
- #90: BUGFIX: Fix type declaration paths.
- #90: BUGFIX: Make web-ext-types a peer dependency.
- This is quick fix until Bug 1694701 is fixed.
- #85: Include type declarations in
@mozilla/glean
webext package bundle.
- #77: Include README.md file in
@mozilla/glean
package bundle.
- #73: Add this changelog file.
- #42: Implement the
deletion-request
ping. - #41: Implement the
logPings
debug tool.- When
logPings
is enabled, pings are logged upon collection.
- When
- #40: Use the dispatcher in all Glean external API functions. Namely:
- Metric recording functions;
- Ping submission;
initialize
andsetUploadEnabled
.
- #36: Implement the event metric type.
- #31: Implement a task Dispatcher to help in executing Promises in a deterministic order.
- #26: Implement the setUploadEnabled API.
- #25: Implement an adapter that leverages browser APIs to upload pings.
- #24: Implement a ping upload manager.
- #23: Implement the initialize API and glean internal metrics.
- #22: Implement the PingType structure and a ping maker.
- #20: Implement the datetime metric type.
- #17: Implement the UUID metric type.
- #14: Implement the counter metric type.
- #13: Implement the string metric type.
- #11: Implement the boolean metric type.
- #9: Implement a metrics database module.
- #8: Implement a web extension version of the underlying storage module.
- #6: Implement an abstract underlying storage module.