# Nuxt Telemetry Module
Nuxt collects anonymous telemetry data about general usage. This helps us to accurately gauge Nuxt feature usage and customization across all our users.
This program is optional. You will be asked on first time to get permission and you can always [opt-out](#opting-out) if you'd not like to share any information.
## Why collecting Telemetry?
Nuxt has grown a lot from its [initial release](https://github.com/nuxt/nuxt.js/releases/tag/v0.2.0) (7 Nov 2016) and we keep listening to [community feedback](https://github.com/nuxt/nuxt.js/issues) to improve it.
However, this manual process only collects feedback from a subset of users that take the time to fill the issue template and it may have different needs or use-case than you.
Nuxt Telemetry collects anonymous telemetry data about general usage. This helps us to accurately gauge feature usage and customization across all our users. This data will let us better understand how Nuxt is used globally, measuring improvements made (DX and performances) and their relevance.
## Events
We collect multiple events:
- Command invoked (`nuxt dev`, `nuxt build`, etc)
- Versions of Nuxt and Node.js
- General machine information (MacOS/Linux/Windows and if the command is run within CI, ci name)
- Duration of the Webpack build and average size of the application, as well as the generation stats (when using `nuxt generate` or `nuxt export`)
- Your project's *public dependencies* (Nuxt modules)
You can see the list of events in [lib/events](./src/events).
Example of an event:
```json
{
"name": "NUXT_PROJECT",
"payload": {
"type": "GIT",
"isSSR": true,
"target": "server",
"isTypescriptBuild": false,
"isTypescriptRuntime": false,
"isProgrammatic": false,
"packageManager": "npm"
}
}
```
To display the exact data that will be sent, you can use `NUXT_TELEMETRY_DEBUG=1`.
## Sensitive data
We take your privacy and our security very seriously.
We do not collect any metrics which may contain sensitive data.
This includes, but is not limited to: environment variables, file paths, contents of files, logs, or serialized JavaScript errors.
The data we collect is completely anonymous, not traceable to the source (using hash+seed), and only meaningful in aggregate form. No data we collect is personally identifiable or trackable.
## Opting-out
You can disable Nuxt Telemetry for your project in several ways:
1. Setting `telemetry: false` in your `nuxt.config`:
```js
export default {
telemetry: false
}
```
2. Using an environment variable:
```bash
NUXT_TELEMETRY_DISABLED=1
```
3. Using `npx nuxt telemetry disable`
```bash
npx nuxt telemetry [status|enable|disable] [-g,--global] [dir]
```
## Skip Prompt
If you encounter problems with the consent prompt and want to participate without being asked this question, you can set `telemetry: true` from `nuxt.config`:
```js
export default {
telemetry: true
}
```
## Thank you
We want to thank you for participating in this telemetry program to help us better understand how you use Nuxt to keep improving it 💚
## Development
- Run `yarn dev:prepare` to generate type stubs.
- Use `yarn dev` to start [playground](./playground) in development mode.
## License
[MIT License](./LICENSE)