JavaScript telemetry tooling for open/inner source projects.
Quality metrics
Overview
IBM Telemetry collects anonymized usage data for open source and inner source packages when they
have been instrumented with this JavaScript tooling. The data is reported back to a central server
so package maintainers can analyze usage and make improvements.
IBM Telemetry uses OpenTelemetry as the foundation of its data transport
format.
Find out more detailed documentation and guidelines by choosing from the following sections what
best describes your use case:
When your project installs an IBM Telemetry-enabled (instrumented) package, IBM Telemetry performs
source code analysis on your project to identify package and component usage. This helps IBM
generate meaningful insights into exactly how much and in what ways the package code is being used
across teams and projects.
What data gets collected?
Depending on the nature of the instrumented package and its telemetry configuration, IBM Telemetry
may capture the following data about your project:
General
Date and time of collection
A de-identified version of your project's git repository URL
A de-identified version of your project's most recent Git commit hash
NPM data
A de-identified version of your project's name (as defined in your package.json file)
Your project's version (as defined in package.json) with any identifiable parts removed
De-identified names and versions of your project's dependencies
JSX data
JSX elements (aka components) imported by your project from the instrumented package and details
about the elements’ attributes (aka props) including names, values, and import paths.
Element attribute names that haven't been specifically configured by the instrumented package to
be collected will be anonymized before collection.
Boolean and number values will be captured for allowed attribute names. String values that haven't
been specifically configured by the instrumented package and other value types (such as complex
objects or variable names) are also anonymized. This means your project-specific data supplied to
JSX elements will never be captured.
All sensitive data that may contain confidential or personally identifiable information that gets
collected by the IBM Telemetry JS tooling gets anonymized/de-identified prior to storage in our
database, see anonymizing.
When does data get collected?
Telemetry collection runs exclusively in CI environments. Collection will never happen on local
development environments or on projects that aren't configured to run automated scripts on a CI
environment (GitHub actions, Travis CI, etc.)
During a build or any other CI operation that installs package dependencies (npm install,
yarn install, ...), IBM telemetry will run as a background process and perform data collection.
Opting out of IBM Telemetry data collection
IBM Telemetry will collect metric data for instrumented packages by default. If your project is
installing an IBM Telemetry-instrumented package and you want to opt-out of metric collection, set
an environment variable of IBM_TELEMETRY_DISABLED='true'. This will prevent any and all data
from being collected in your project.
Anonymizing / de-identifying
When data is to be de-identified, it is hashed using the SHA-256 cryptographic function, meaning an
instrumented package owner can query for specific known names/values but can never recover original
values from the stored data in the database.
When data is to be anonymized, it is redacted/substituted in a way where its original value can
never be recovered, and there is no meaningful way to query the data to ascertain its value.
As a general philosophy, we favor anonymizing fields over de-identifying them.
Onboarding a package to IBM Telemetry
1. Obtain a project ID from the IBM Telemetry team by opening an issue here.
The IBM Telemetry team will assign you a project ID to include in your telemetry.yml config file.
2. Create a telemetry.yml config file.
[!IMPORTANT] This config file needs to be included in your published NPM package!
This file defines what types of metrics will be captured for your project as well as some general
configuration settings.
See the telemetry config schema for a
detailed explanation of all available configuration options.
Note: Though this file can live anywhere within your project, it is customary to place it at
the root level.
3. Add a postinstall script to your package.json file.
It is not necessary for your package to directly install IBM Telemetry as a dependency. Instead,
use npx to call the published collection script directly from the @ibm/telemetry-js package.
The postinstall script runs telemetry collection anytime your package gets installed inside of
another project.
Make sure the --config options points to your telemetry.yml file within your package.
4. Add telemetry collection notice to your docs.
You'll want to be as transparent as possible about telemetry collection and the data that is being
stored. You should strongly consider adding an informational paragraph to your docs (usually the
README) as follows:
## <picture><sourceheight="20"width="20"media="(prefers-color-scheme: dark)"srcset="https://raw.githubusercontent.com/ibm-telemetry/telemetry-js/main/docs/images/ibm-telemetry-dark.svg"><sourceheight="20"width="20"media="(prefers-color-scheme: light)"srcset="https://raw.githubusercontent.com/ibm-telemetry/telemetry-js/main/docs/images/ibm-telemetry-light.svg"><imgheight="20"width="20"alt="IBM Telemetry"src="https://raw.githubusercontent.com/ibm-telemetry/telemetry-js/main/docs/images/ibm-telemetry-light.svg"></picture> IBM Telemetry
This package uses IBM Telemetry to collect metrics data. By installing this package as a dependency
you are agreeing to telemetry collection. To opt out, see
[Opting out of IBM Telemetry data collection](https://github.com/ibm-telemetry/telemetry-js/tree/main#opting-out-of-ibm-telemetry-data-collection).
For more information on the data being collected, please see the
[IBM Telemetry documentation](https://github.com/ibm-telemetry/telemetry-js/tree/main#ibm-telemetry-collection-basics).
Preview notice
IBM Telemetry
This package uses IBM Telemetry to collect metrics data. By installing this package as a dependency
you are agreeing to telemetry collection. To opt out, see
Opting out of IBM Telemetry data collection.
For more information on the data being collected, please see the
IBM Telemetry documentation.
5. Publish a new version of your package.
Package consumers need to install a version of your package that includes both the config file and
post-install script in order for telemetry collection to occur.
6. Done!
Whenever consumers pick up a version of your package that includes the config file and post-install
script, telemetry collection will run and collect metrics.
I don't work for IBM. Can I still use this?
Yes! This package can send its output to any OpenTelemetry-compatible collector endpoint via the
standard v1/metricsRest API endpoint. All you need to do
is specify your collector endpoint's URL in the endpoint configuration setting in your
telemetry.yml file.
JavaScript telemetry tooling for open/inner source projects
The npm package @ibm/telemetry-js receives a total of 23,181 weekly downloads. As such, @ibm/telemetry-js popularity was classified as popular.
We found that @ibm/telemetry-js demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago.It has 22 open source maintainers collaborating on the project.
Package last updated on 18 Dec 2023
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
A malicious npm package disguised as a WhatsApp client is exploiting authentication flows with a remote kill switch to exfiltrate data and destroy files.
GitHub removed 27 malicious pull requests attempting to inject harmful code across multiple open source repositories, in another round of low-effort attacks.