detect package manager and improve types (#3847)
This commit is contained in:
parent
4fb08502a9
commit
eedb32c797
7 changed files with 79 additions and 45 deletions
5
.changeset/silent-readers-behave.md
Normal file
5
.changeset/silent-readers-behave.md
Normal file
|
@ -0,0 +1,5 @@
|
|||
---
|
||||
'@astrojs/telemetry': patch
|
||||
---
|
||||
|
||||
Detect package manager, improve types
|
|
@ -28,19 +28,21 @@
|
|||
"create-astro.js"
|
||||
],
|
||||
"dependencies": {
|
||||
"@types/degit": "^2.8.3",
|
||||
"@types/prompts": "^2.0.14",
|
||||
"chalk": "^5.0.1",
|
||||
"degit": "^2.8.4",
|
||||
"execa": "^6.1.0",
|
||||
"kleur": "^4.1.4",
|
||||
"ora": "^6.1.0",
|
||||
"prompts": "^2.4.2",
|
||||
"which-pm-runs": "^1.1.0",
|
||||
"yargs-parser": "^21.0.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@types/chai": "^4.3.1",
|
||||
"@types/degit": "^2.8.3",
|
||||
"@types/mocha": "^9.1.1",
|
||||
"@types/prompts": "^2.0.14",
|
||||
"@types/which-pm-runs": "^1.0.0",
|
||||
"@types/yargs-parser": "^21.0.0",
|
||||
"astro-scripts": "workspace:*",
|
||||
"chai": "^4.3.6",
|
||||
|
|
|
@ -10,6 +10,7 @@ import yargs from 'yargs-parser';
|
|||
import { loadWithRocketGradient, rocketAscii } from './gradient.js';
|
||||
import { defaultLogLevel, logger } from './logger.js';
|
||||
import { TEMPLATES } from './templates.js';
|
||||
import detectPackageManager from 'which-pm-runs';
|
||||
|
||||
function wait(ms: number) {
|
||||
return new Promise((resolve) => setTimeout(resolve, ms));
|
||||
|
@ -48,7 +49,7 @@ const FILES_TO_REMOVE = ['.stackblitzrc', 'sandbox.config.json', 'CHANGELOG.md']
|
|||
|
||||
// Please also update the installation instructions in the docs at https://github.com/withastro/docs/blob/main/src/pages/en/install/auto.md if you make any changes to the flow or wording here.
|
||||
export async function main() {
|
||||
const pkgManager = pkgManagerFromUserAgent(process.env.npm_config_user_agent);
|
||||
const pkgManager = detectPackageManager()?.name || 'npm';
|
||||
|
||||
logger.debug('Verbose logging turned on');
|
||||
console.log(`\n${bold('Welcome to Astro!')} ${gray(`(create-astro v${version})`)}`);
|
||||
|
@ -251,18 +252,3 @@ function emojiWithFallback(char: string, fallback: string) {
|
|||
return process.platform !== 'win32' ? char : fallback;
|
||||
}
|
||||
|
||||
function pkgManagerFromUserAgent(userAgent?: string) {
|
||||
if (!userAgent) return 'npm';
|
||||
const pkgSpec = userAgent.split(' ')[0];
|
||||
const pkgSpecArr = pkgSpec.split('/');
|
||||
return pkgSpecArr[0];
|
||||
}
|
||||
|
||||
function pkgManagerExecCommand(pkgManager: string) {
|
||||
if (pkgManager === 'pnpm') {
|
||||
return 'pnpx';
|
||||
} else {
|
||||
// note: yarn does not have an "npx" equivalent
|
||||
return 'npx';
|
||||
}
|
||||
}
|
||||
|
|
|
@ -34,11 +34,13 @@
|
|||
"git-up": "^4.0.5",
|
||||
"is-docker": "^3.0.0",
|
||||
"is-wsl": "^2.2.0",
|
||||
"node-fetch": "^3.2.5"
|
||||
"node-fetch": "^3.2.5",
|
||||
"which-pm-runs": "^1.1.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@types/dlv": "^1.1.2",
|
||||
"@types/node": "^14.18.21",
|
||||
"@types/which-pm-runs": "^1.0.0",
|
||||
"astro-scripts": "workspace:*"
|
||||
},
|
||||
"engines": {
|
||||
|
|
|
@ -9,14 +9,11 @@ import { getSystemInfo, SystemInfo } from './system-info.js';
|
|||
|
||||
export type AstroTelemetryOptions = { astroVersion: string; viteVersion: string };
|
||||
export type TelemetryEvent = { eventName: string; payload: Record<string, any> };
|
||||
interface EventContext {
|
||||
anonymousId: string;
|
||||
anonymousProjectId: string;
|
||||
anonymousSessionId: string;
|
||||
}
|
||||
|
||||
interface EventMeta extends SystemInfo {
|
||||
isGit: boolean;
|
||||
interface EventMeta extends SystemInfo {}
|
||||
interface EventContext extends ProjectInfo {
|
||||
anonymousId: string;
|
||||
anonymousSessionId: string;
|
||||
}
|
||||
export class AstroTelemetry {
|
||||
private _anonymousSessionId: string | undefined;
|
||||
|
@ -118,29 +115,19 @@ export class AstroTelemetry {
|
|||
return Promise.resolve();
|
||||
}
|
||||
|
||||
if (this.debug.enabled) {
|
||||
// Print to standard error to simplify selecting the output
|
||||
events.forEach(({ eventName, payload }) =>
|
||||
this.debug(JSON.stringify({ eventName, payload }, null, 2))
|
||||
);
|
||||
// Do not send the telemetry data if debugging. Users may use this feature
|
||||
// to preview what data would be sent.
|
||||
return Promise.resolve();
|
||||
}
|
||||
|
||||
// Skip recording telemetry if the feature is disabled
|
||||
if (this.isDisabled) {
|
||||
this.debug('telemetry disabled');
|
||||
return Promise.resolve();
|
||||
}
|
||||
|
||||
const meta: EventMeta = {
|
||||
...getSystemInfo({ astroVersion: this.astroVersion, viteVersion: this.viteVersion }),
|
||||
isGit: this.anonymousProjectInfo.isGit,
|
||||
};
|
||||
|
||||
const context: EventContext = {
|
||||
...this.anonymousProjectInfo,
|
||||
anonymousId: this.anonymousId,
|
||||
anonymousProjectId: this.anonymousProjectInfo.anonymousProjectId,
|
||||
anonymousSessionId: this.anonymousSessionId,
|
||||
};
|
||||
|
||||
|
@ -150,6 +137,15 @@ export class AstroTelemetry {
|
|||
context.anonymousId = `CI.${meta.ciName || 'UNKNOWN'}`;
|
||||
}
|
||||
|
||||
if (this.debug.enabled) {
|
||||
// Print to standard error to simplify selecting the output
|
||||
this.debug({ context, meta });
|
||||
this.debug(JSON.stringify(events, null, 2));
|
||||
// Do not send the telemetry data if debugging. Users may use this feature
|
||||
// to preview what data would be sent.
|
||||
return Promise.resolve();
|
||||
}
|
||||
|
||||
return post({
|
||||
context,
|
||||
meta,
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
import { execSync } from 'child_process';
|
||||
import type { BinaryLike } from 'node:crypto';
|
||||
import { createHash } from 'node:crypto';
|
||||
import detectPackageManager from 'which-pm-runs';
|
||||
|
||||
/**
|
||||
* Astro Telemetry -- Project Info
|
||||
|
@ -46,9 +47,13 @@ import { createHash } from 'node:crypto';
|
|||
|
||||
export interface ProjectInfo {
|
||||
/* Your unique project identifier. This will be hashed again before sending. */
|
||||
anonymousProjectId: string;
|
||||
anonymousProjectId: string | undefined;
|
||||
/* true if your project is connected to a git repository. false otherwise. */
|
||||
isGit: boolean;
|
||||
/* The package manager used to run Astro */
|
||||
packageManager: string | undefined;
|
||||
/* The version of the package manager used to run Astro */
|
||||
packageManagerVersion: string | undefined;
|
||||
}
|
||||
|
||||
function createAnonymousValue(payload: BinaryLike): string {
|
||||
|
@ -75,7 +80,7 @@ function getProjectIdFromGit(): string | null {
|
|||
}
|
||||
}
|
||||
|
||||
export function getProjectInfo(isCI: boolean): ProjectInfo {
|
||||
function getProjectId(isCI: boolean): Pick<ProjectInfo, 'isGit' | 'anonymousProjectId'> {
|
||||
const projectIdFromGit = getProjectIdFromGit();
|
||||
if (projectIdFromGit) {
|
||||
return {
|
||||
|
@ -83,8 +88,29 @@ export function getProjectInfo(isCI: boolean): ProjectInfo {
|
|||
anonymousProjectId: createAnonymousValue(projectIdFromGit),
|
||||
};
|
||||
}
|
||||
// If we're running in CI, the current working directory is not unique.
|
||||
// If the cwd is a single level deep (ex: '/app'), it's probably not unique.
|
||||
const cwd = process.cwd();
|
||||
const isCwdGeneric = (cwd.match(/[\/|\\]/g) || []).length === 1;
|
||||
if (isCI || isCwdGeneric) {
|
||||
return {
|
||||
isGit: false,
|
||||
anonymousProjectId: isCI ? '' : createAnonymousValue(process.cwd()),
|
||||
anonymousProjectId: undefined,
|
||||
};
|
||||
}
|
||||
return {
|
||||
isGit: false,
|
||||
anonymousProjectId: createAnonymousValue(cwd),
|
||||
};
|
||||
}
|
||||
|
||||
export function getProjectInfo(isCI: boolean): ProjectInfo {
|
||||
const projectId = getProjectId(isCI);
|
||||
const packageManager = detectPackageManager();
|
||||
return {
|
||||
...projectId,
|
||||
packageManager: packageManager?.name,
|
||||
packageManagerVersion: packageManager?.version,
|
||||
};
|
||||
}
|
||||
//
|
||||
|
|
|
@ -1844,6 +1844,7 @@ importers:
|
|||
'@types/degit': ^2.8.3
|
||||
'@types/mocha': ^9.1.1
|
||||
'@types/prompts': ^2.0.14
|
||||
'@types/which-pm-runs': ^1.0.0
|
||||
'@types/yargs-parser': ^21.0.0
|
||||
astro-scripts: workspace:*
|
||||
chai: ^4.3.6
|
||||
|
@ -1855,20 +1856,23 @@ importers:
|
|||
ora: ^6.1.0
|
||||
prompts: ^2.4.2
|
||||
uvu: ^0.5.3
|
||||
which-pm-runs: ^1.1.0
|
||||
yargs-parser: ^21.0.1
|
||||
dependencies:
|
||||
'@types/degit': 2.8.3
|
||||
'@types/prompts': 2.0.14
|
||||
chalk: 5.0.1
|
||||
degit: 2.8.4
|
||||
execa: 6.1.0
|
||||
kleur: 4.1.5
|
||||
ora: 6.1.2
|
||||
prompts: 2.4.2
|
||||
which-pm-runs: 1.1.0
|
||||
yargs-parser: 21.0.1
|
||||
devDependencies:
|
||||
'@types/chai': 4.3.1
|
||||
'@types/degit': 2.8.3
|
||||
'@types/mocha': 9.1.1
|
||||
'@types/prompts': 2.0.14
|
||||
'@types/which-pm-runs': 1.0.0
|
||||
'@types/yargs-parser': 21.0.0
|
||||
astro-scripts: link:../../scripts
|
||||
chai: 4.3.6
|
||||
|
@ -2310,6 +2314,7 @@ importers:
|
|||
specifiers:
|
||||
'@types/dlv': ^1.1.2
|
||||
'@types/node': ^14.18.21
|
||||
'@types/which-pm-runs': ^1.0.0
|
||||
astro-scripts: workspace:*
|
||||
ci-info: ^3.3.1
|
||||
debug: ^4.3.4
|
||||
|
@ -2320,6 +2325,7 @@ importers:
|
|||
is-docker: ^3.0.0
|
||||
is-wsl: ^2.2.0
|
||||
node-fetch: ^3.2.5
|
||||
which-pm-runs: ^1.1.0
|
||||
dependencies:
|
||||
ci-info: 3.3.2
|
||||
debug: 4.3.4
|
||||
|
@ -2330,9 +2336,11 @@ importers:
|
|||
is-docker: 3.0.0
|
||||
is-wsl: 2.2.0
|
||||
node-fetch: 3.2.6
|
||||
which-pm-runs: 1.1.0
|
||||
devDependencies:
|
||||
'@types/dlv': 1.1.2
|
||||
'@types/node': 14.18.21
|
||||
'@types/which-pm-runs': 1.0.0
|
||||
astro-scripts: link:../../scripts
|
||||
|
||||
packages/webapi:
|
||||
|
@ -7385,7 +7393,7 @@ packages:
|
|||
|
||||
/@types/degit/2.8.3:
|
||||
resolution: {integrity: sha512-CL7y71j2zaDmtPLD5Xq5S1Gv2dFoHl0/GBZm6s39Mj/ls28L3NzAOqf7H4H0/2TNVMgMjMVf9CAFYSjmXhi3bw==}
|
||||
dev: false
|
||||
dev: true
|
||||
|
||||
/@types/diff/5.0.2:
|
||||
resolution: {integrity: sha512-uw8eYMIReOwstQ0QKF0sICefSy8cNO/v7gOTiIy9SbwuHyEecJUm7qlgueOO5S1udZ5I/irVydHVwMchgzbKTg==}
|
||||
|
@ -7536,7 +7544,7 @@ packages:
|
|||
resolution: {integrity: sha512-HZBd99fKxRWpYCErtm2/yxUZv6/PBI9J7N4TNFffl5JbrYMHBwF25DjQGTW3b3jmXq+9P6/8fCIb2ee57BFfYA==}
|
||||
dependencies:
|
||||
'@types/node': 18.0.0
|
||||
dev: false
|
||||
dev: true
|
||||
|
||||
/@types/prop-types/15.7.5:
|
||||
resolution: {integrity: sha512-JCB8C6SnDoQf0cNycqd/35A7MjcnK+ZTqE7judS6o7utxUCg6imJg3QK2qzHKszlTjcj2cn+NwMB2i96ubpj7w==}
|
||||
|
@ -7642,6 +7650,10 @@ packages:
|
|||
/@types/unist/2.0.6:
|
||||
resolution: {integrity: sha512-PBjIUxZHOuj0R15/xuwJYjFi+KZdNFrehocChv4g5hu6aFroHue8m0lBP0POdK2nKzbw0cgV1mws8+V/JAcEkQ==}
|
||||
|
||||
/@types/which-pm-runs/1.0.0:
|
||||
resolution: {integrity: sha512-BXfdlYLWvRhngJbih4N57DjO+63Z7AxiFiip8yq3rD46U7V4I2W538gngPvBsZiMehhD8sfGf4xLI6k7TgXvNw==}
|
||||
dev: true
|
||||
|
||||
/@types/yargs-parser/21.0.0:
|
||||
resolution: {integrity: sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==}
|
||||
dev: true
|
||||
|
@ -15157,6 +15169,11 @@ packages:
|
|||
resolution: {integrity: sha512-B+enWhmw6cjfVC7kS8Pj9pCrKSc5txArRyaYGe088shv/FGWH+0Rjx/xPgtsWfsUtS27FkP697E4DDhgrgoc0Q==}
|
||||
dev: true
|
||||
|
||||
/which-pm-runs/1.1.0:
|
||||
resolution: {integrity: sha512-n1brCuqClxfFfq/Rb0ICg9giSZqCS+pLtccdag6C2HyufBrh3fBOiy9nb6ggRMvWOVH5GrdJskj5iGTZNxd7SA==}
|
||||
engines: {node: '>=4'}
|
||||
dev: false
|
||||
|
||||
/which-pm/2.0.0:
|
||||
resolution: {integrity: sha512-Lhs9Pmyph0p5n5Z3mVnN0yWcbQYUAD7rbQUiMsQxOJ3T57k7RFe35SUwWMf7dsbDZks1uOmw4AecB/JMDj3v/w==}
|
||||
engines: {node: '>=8.15'}
|
||||
|
|
Loading…
Reference in a new issue