mirror of
https://github.com/FranP-code/create-better-t-stack.git
synced 2025-10-12 23:52:15 +00:00
feat(cli): allow disable telemetry
This commit is contained in:
5
.changeset/six-pears-joke.md
Normal file
5
.changeset/six-pears-joke.md
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
"create-better-t-stack": patch
|
||||
---
|
||||
|
||||
Allow disabling telemetry with BTS_TELEMETRY_DISABLED=1
|
||||
2
.github/workflows/release.yaml
vendored
2
.github/workflows/release.yaml
vendored
@@ -36,7 +36,7 @@ jobs:
|
||||
with:
|
||||
publish: bun run publish-packages
|
||||
env:
|
||||
TELEMETRY: "true"
|
||||
BTS_TELEMETRY: 1
|
||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
|
||||
POSTHOG_API_KEY: ${{ secrets.POSTHOG_API_KEY }}
|
||||
|
||||
@@ -66,6 +66,32 @@ Options:
|
||||
-h, --help Display help
|
||||
```
|
||||
|
||||
## Telemetry
|
||||
|
||||
This CLI collects anonymous usage data to help improve the tool. The data collected includes:
|
||||
- Configuration options selected
|
||||
- CLI version
|
||||
- Node.js version
|
||||
- Platform (OS)
|
||||
|
||||
**Telemetry is enabled by default in published versions** to help us understand usage patterns and improve the tool.
|
||||
|
||||
### Disabling Telemetry
|
||||
|
||||
You can disable telemetry by setting the `BTS_TELEMETRY` environment variable:
|
||||
|
||||
```bash
|
||||
# Disable telemetry for a single run
|
||||
BTS_TELEMETRY=0 npx create-better-t-stack my-app
|
||||
|
||||
# Disable telemetry globally in your shell profile (.bashrc, .zshrc, etc.)
|
||||
export BTS_TELEMETRY=0
|
||||
```
|
||||
|
||||
### Development
|
||||
|
||||
During development, telemetry is automatically disabled when `NODE_ENV=development`.
|
||||
|
||||
## Examples
|
||||
|
||||
Create a project with default configuration:
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
import { PostHog } from "posthog-node";
|
||||
import type { ProjectConfig } from "../types";
|
||||
import { getLatestCLIVersion } from "./get-latest-cli-version";
|
||||
import { isTelemetryEnabled } from "./telemetry";
|
||||
|
||||
const POSTHOG_API_KEY = process.env.POSTHOG_API_KEY || "";
|
||||
const POSTHOG_HOST = process.env.POSTHOG_HOST;
|
||||
@@ -14,7 +15,7 @@ export async function trackProjectCreation(
|
||||
flushInterval: 0,
|
||||
privacyMode: true,
|
||||
disableGeoip: true,
|
||||
disabled: process.env.TELEMETRY !== "true",
|
||||
disabled: !isTelemetryEnabled(),
|
||||
});
|
||||
|
||||
try {
|
||||
|
||||
34
apps/cli/src/utils/telemetry.ts
Normal file
34
apps/cli/src/utils/telemetry.ts
Normal file
@@ -0,0 +1,34 @@
|
||||
/**
|
||||
* Utility function to determine if telemetry should be enabled.
|
||||
*
|
||||
* Telemetry is enabled by default in production, but can be disabled by:
|
||||
* - Setting BTS_TELEMETRY=0 or BTS_TELEMETRY=false
|
||||
* - Running in development environment (NODE_ENV=development)
|
||||
*/
|
||||
export function isTelemetryEnabled(): boolean {
|
||||
// If user explicitly disabled telemetry
|
||||
if (
|
||||
process.env.BTS_TELEMETRY === "0" ||
|
||||
process.env.BTS_TELEMETRY === "false"
|
||||
) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// If user explicitly enabled telemetry
|
||||
if (
|
||||
process.env.BTS_TELEMETRY === "1" ||
|
||||
process.env.BTS_TELEMETRY === "true"
|
||||
) {
|
||||
return true;
|
||||
}
|
||||
|
||||
if (
|
||||
process.env.BTS_TELEMETRY_DISABLED === "1" ||
|
||||
process.env.BTS_TELEMETRY_DISABLED === "true"
|
||||
) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// Default to enabled in production
|
||||
return true;
|
||||
}
|
||||
@@ -10,8 +10,8 @@ export default defineConfig({
|
||||
banner: "#!/usr/bin/env node",
|
||||
},
|
||||
env: {
|
||||
POSTHOG_API_KEY: process.env.POSTHOG_API_KEY || "lol",
|
||||
POSTHOG_HOST: process.env.POSTHOG_HOST || "lool",
|
||||
TELEMETRY: process.env.TELEMETRY || "false", // wierd trick i know
|
||||
POSTHOG_API_KEY: process.env.POSTHOG_API_KEY || "random",
|
||||
POSTHOG_HOST: process.env.POSTHOG_HOST || "random",
|
||||
BTS_TELEMETRY: process.env.BTS_TELEMETRY || "0",
|
||||
},
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user