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"
|
"create-astro.js"
|
||||||
],
|
],
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@types/degit": "^2.8.3",
|
|
||||||
"@types/prompts": "^2.0.14",
|
|
||||||
"chalk": "^5.0.1",
|
"chalk": "^5.0.1",
|
||||||
"degit": "^2.8.4",
|
"degit": "^2.8.4",
|
||||||
"execa": "^6.1.0",
|
"execa": "^6.1.0",
|
||||||
"kleur": "^4.1.4",
|
"kleur": "^4.1.4",
|
||||||
"ora": "^6.1.0",
|
"ora": "^6.1.0",
|
||||||
"prompts": "^2.4.2",
|
"prompts": "^2.4.2",
|
||||||
|
"which-pm-runs": "^1.1.0",
|
||||||
"yargs-parser": "^21.0.1"
|
"yargs-parser": "^21.0.1"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/chai": "^4.3.1",
|
"@types/chai": "^4.3.1",
|
||||||
|
"@types/degit": "^2.8.3",
|
||||||
"@types/mocha": "^9.1.1",
|
"@types/mocha": "^9.1.1",
|
||||||
|
"@types/prompts": "^2.0.14",
|
||||||
|
"@types/which-pm-runs": "^1.0.0",
|
||||||
"@types/yargs-parser": "^21.0.0",
|
"@types/yargs-parser": "^21.0.0",
|
||||||
"astro-scripts": "workspace:*",
|
"astro-scripts": "workspace:*",
|
||||||
"chai": "^4.3.6",
|
"chai": "^4.3.6",
|
||||||
|
|
|
@ -10,6 +10,7 @@ import yargs from 'yargs-parser';
|
||||||
import { loadWithRocketGradient, rocketAscii } from './gradient.js';
|
import { loadWithRocketGradient, rocketAscii } from './gradient.js';
|
||||||
import { defaultLogLevel, logger } from './logger.js';
|
import { defaultLogLevel, logger } from './logger.js';
|
||||||
import { TEMPLATES } from './templates.js';
|
import { TEMPLATES } from './templates.js';
|
||||||
|
import detectPackageManager from 'which-pm-runs';
|
||||||
|
|
||||||
function wait(ms: number) {
|
function wait(ms: number) {
|
||||||
return new Promise((resolve) => setTimeout(resolve, ms));
|
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.
|
// 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() {
|
export async function main() {
|
||||||
const pkgManager = pkgManagerFromUserAgent(process.env.npm_config_user_agent);
|
const pkgManager = detectPackageManager()?.name || 'npm';
|
||||||
|
|
||||||
logger.debug('Verbose logging turned on');
|
logger.debug('Verbose logging turned on');
|
||||||
console.log(`\n${bold('Welcome to Astro!')} ${gray(`(create-astro v${version})`)}`);
|
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;
|
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",
|
"git-up": "^4.0.5",
|
||||||
"is-docker": "^3.0.0",
|
"is-docker": "^3.0.0",
|
||||||
"is-wsl": "^2.2.0",
|
"is-wsl": "^2.2.0",
|
||||||
"node-fetch": "^3.2.5"
|
"node-fetch": "^3.2.5",
|
||||||
|
"which-pm-runs": "^1.1.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/dlv": "^1.1.2",
|
"@types/dlv": "^1.1.2",
|
||||||
"@types/node": "^14.18.21",
|
"@types/node": "^14.18.21",
|
||||||
|
"@types/which-pm-runs": "^1.0.0",
|
||||||
"astro-scripts": "workspace:*"
|
"astro-scripts": "workspace:*"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
|
|
|
@ -9,14 +9,11 @@ import { getSystemInfo, SystemInfo } from './system-info.js';
|
||||||
|
|
||||||
export type AstroTelemetryOptions = { astroVersion: string; viteVersion: string };
|
export type AstroTelemetryOptions = { astroVersion: string; viteVersion: string };
|
||||||
export type TelemetryEvent = { eventName: string; payload: Record<string, any> };
|
export type TelemetryEvent = { eventName: string; payload: Record<string, any> };
|
||||||
interface EventContext {
|
|
||||||
anonymousId: string;
|
|
||||||
anonymousProjectId: string;
|
|
||||||
anonymousSessionId: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface EventMeta extends SystemInfo {
|
interface EventMeta extends SystemInfo {}
|
||||||
isGit: boolean;
|
interface EventContext extends ProjectInfo {
|
||||||
|
anonymousId: string;
|
||||||
|
anonymousSessionId: string;
|
||||||
}
|
}
|
||||||
export class AstroTelemetry {
|
export class AstroTelemetry {
|
||||||
private _anonymousSessionId: string | undefined;
|
private _anonymousSessionId: string | undefined;
|
||||||
|
@ -118,29 +115,19 @@ export class AstroTelemetry {
|
||||||
return Promise.resolve();
|
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
|
// Skip recording telemetry if the feature is disabled
|
||||||
if (this.isDisabled) {
|
if (this.isDisabled) {
|
||||||
|
this.debug('telemetry disabled');
|
||||||
return Promise.resolve();
|
return Promise.resolve();
|
||||||
}
|
}
|
||||||
|
|
||||||
const meta: EventMeta = {
|
const meta: EventMeta = {
|
||||||
...getSystemInfo({ astroVersion: this.astroVersion, viteVersion: this.viteVersion }),
|
...getSystemInfo({ astroVersion: this.astroVersion, viteVersion: this.viteVersion }),
|
||||||
isGit: this.anonymousProjectInfo.isGit,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const context: EventContext = {
|
const context: EventContext = {
|
||||||
|
...this.anonymousProjectInfo,
|
||||||
anonymousId: this.anonymousId,
|
anonymousId: this.anonymousId,
|
||||||
anonymousProjectId: this.anonymousProjectInfo.anonymousProjectId,
|
|
||||||
anonymousSessionId: this.anonymousSessionId,
|
anonymousSessionId: this.anonymousSessionId,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -150,6 +137,15 @@ export class AstroTelemetry {
|
||||||
context.anonymousId = `CI.${meta.ciName || 'UNKNOWN'}`;
|
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({
|
return post({
|
||||||
context,
|
context,
|
||||||
meta,
|
meta,
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
import { execSync } from 'child_process';
|
import { execSync } from 'child_process';
|
||||||
import type { BinaryLike } from 'node:crypto';
|
import type { BinaryLike } from 'node:crypto';
|
||||||
import { createHash } from 'node:crypto';
|
import { createHash } from 'node:crypto';
|
||||||
|
import detectPackageManager from 'which-pm-runs';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Astro Telemetry -- Project Info
|
* Astro Telemetry -- Project Info
|
||||||
|
@ -46,9 +47,13 @@ import { createHash } from 'node:crypto';
|
||||||
|
|
||||||
export interface ProjectInfo {
|
export interface ProjectInfo {
|
||||||
/* Your unique project identifier. This will be hashed again before sending. */
|
/* 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. */
|
/* true if your project is connected to a git repository. false otherwise. */
|
||||||
isGit: boolean;
|
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 {
|
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();
|
const projectIdFromGit = getProjectIdFromGit();
|
||||||
if (projectIdFromGit) {
|
if (projectIdFromGit) {
|
||||||
return {
|
return {
|
||||||
|
@ -83,8 +88,29 @@ export function getProjectInfo(isCI: boolean): ProjectInfo {
|
||||||
anonymousProjectId: createAnonymousValue(projectIdFromGit),
|
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 {
|
return {
|
||||||
isGit: false,
|
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/degit': ^2.8.3
|
||||||
'@types/mocha': ^9.1.1
|
'@types/mocha': ^9.1.1
|
||||||
'@types/prompts': ^2.0.14
|
'@types/prompts': ^2.0.14
|
||||||
|
'@types/which-pm-runs': ^1.0.0
|
||||||
'@types/yargs-parser': ^21.0.0
|
'@types/yargs-parser': ^21.0.0
|
||||||
astro-scripts: workspace:*
|
astro-scripts: workspace:*
|
||||||
chai: ^4.3.6
|
chai: ^4.3.6
|
||||||
|
@ -1855,20 +1856,23 @@ importers:
|
||||||
ora: ^6.1.0
|
ora: ^6.1.0
|
||||||
prompts: ^2.4.2
|
prompts: ^2.4.2
|
||||||
uvu: ^0.5.3
|
uvu: ^0.5.3
|
||||||
|
which-pm-runs: ^1.1.0
|
||||||
yargs-parser: ^21.0.1
|
yargs-parser: ^21.0.1
|
||||||
dependencies:
|
dependencies:
|
||||||
'@types/degit': 2.8.3
|
|
||||||
'@types/prompts': 2.0.14
|
|
||||||
chalk: 5.0.1
|
chalk: 5.0.1
|
||||||
degit: 2.8.4
|
degit: 2.8.4
|
||||||
execa: 6.1.0
|
execa: 6.1.0
|
||||||
kleur: 4.1.5
|
kleur: 4.1.5
|
||||||
ora: 6.1.2
|
ora: 6.1.2
|
||||||
prompts: 2.4.2
|
prompts: 2.4.2
|
||||||
|
which-pm-runs: 1.1.0
|
||||||
yargs-parser: 21.0.1
|
yargs-parser: 21.0.1
|
||||||
devDependencies:
|
devDependencies:
|
||||||
'@types/chai': 4.3.1
|
'@types/chai': 4.3.1
|
||||||
|
'@types/degit': 2.8.3
|
||||||
'@types/mocha': 9.1.1
|
'@types/mocha': 9.1.1
|
||||||
|
'@types/prompts': 2.0.14
|
||||||
|
'@types/which-pm-runs': 1.0.0
|
||||||
'@types/yargs-parser': 21.0.0
|
'@types/yargs-parser': 21.0.0
|
||||||
astro-scripts: link:../../scripts
|
astro-scripts: link:../../scripts
|
||||||
chai: 4.3.6
|
chai: 4.3.6
|
||||||
|
@ -2310,6 +2314,7 @@ importers:
|
||||||
specifiers:
|
specifiers:
|
||||||
'@types/dlv': ^1.1.2
|
'@types/dlv': ^1.1.2
|
||||||
'@types/node': ^14.18.21
|
'@types/node': ^14.18.21
|
||||||
|
'@types/which-pm-runs': ^1.0.0
|
||||||
astro-scripts: workspace:*
|
astro-scripts: workspace:*
|
||||||
ci-info: ^3.3.1
|
ci-info: ^3.3.1
|
||||||
debug: ^4.3.4
|
debug: ^4.3.4
|
||||||
|
@ -2320,6 +2325,7 @@ importers:
|
||||||
is-docker: ^3.0.0
|
is-docker: ^3.0.0
|
||||||
is-wsl: ^2.2.0
|
is-wsl: ^2.2.0
|
||||||
node-fetch: ^3.2.5
|
node-fetch: ^3.2.5
|
||||||
|
which-pm-runs: ^1.1.0
|
||||||
dependencies:
|
dependencies:
|
||||||
ci-info: 3.3.2
|
ci-info: 3.3.2
|
||||||
debug: 4.3.4
|
debug: 4.3.4
|
||||||
|
@ -2330,9 +2336,11 @@ importers:
|
||||||
is-docker: 3.0.0
|
is-docker: 3.0.0
|
||||||
is-wsl: 2.2.0
|
is-wsl: 2.2.0
|
||||||
node-fetch: 3.2.6
|
node-fetch: 3.2.6
|
||||||
|
which-pm-runs: 1.1.0
|
||||||
devDependencies:
|
devDependencies:
|
||||||
'@types/dlv': 1.1.2
|
'@types/dlv': 1.1.2
|
||||||
'@types/node': 14.18.21
|
'@types/node': 14.18.21
|
||||||
|
'@types/which-pm-runs': 1.0.0
|
||||||
astro-scripts: link:../../scripts
|
astro-scripts: link:../../scripts
|
||||||
|
|
||||||
packages/webapi:
|
packages/webapi:
|
||||||
|
@ -7385,7 +7393,7 @@ packages:
|
||||||
|
|
||||||
/@types/degit/2.8.3:
|
/@types/degit/2.8.3:
|
||||||
resolution: {integrity: sha512-CL7y71j2zaDmtPLD5Xq5S1Gv2dFoHl0/GBZm6s39Mj/ls28L3NzAOqf7H4H0/2TNVMgMjMVf9CAFYSjmXhi3bw==}
|
resolution: {integrity: sha512-CL7y71j2zaDmtPLD5Xq5S1Gv2dFoHl0/GBZm6s39Mj/ls28L3NzAOqf7H4H0/2TNVMgMjMVf9CAFYSjmXhi3bw==}
|
||||||
dev: false
|
dev: true
|
||||||
|
|
||||||
/@types/diff/5.0.2:
|
/@types/diff/5.0.2:
|
||||||
resolution: {integrity: sha512-uw8eYMIReOwstQ0QKF0sICefSy8cNO/v7gOTiIy9SbwuHyEecJUm7qlgueOO5S1udZ5I/irVydHVwMchgzbKTg==}
|
resolution: {integrity: sha512-uw8eYMIReOwstQ0QKF0sICefSy8cNO/v7gOTiIy9SbwuHyEecJUm7qlgueOO5S1udZ5I/irVydHVwMchgzbKTg==}
|
||||||
|
@ -7536,7 +7544,7 @@ packages:
|
||||||
resolution: {integrity: sha512-HZBd99fKxRWpYCErtm2/yxUZv6/PBI9J7N4TNFffl5JbrYMHBwF25DjQGTW3b3jmXq+9P6/8fCIb2ee57BFfYA==}
|
resolution: {integrity: sha512-HZBd99fKxRWpYCErtm2/yxUZv6/PBI9J7N4TNFffl5JbrYMHBwF25DjQGTW3b3jmXq+9P6/8fCIb2ee57BFfYA==}
|
||||||
dependencies:
|
dependencies:
|
||||||
'@types/node': 18.0.0
|
'@types/node': 18.0.0
|
||||||
dev: false
|
dev: true
|
||||||
|
|
||||||
/@types/prop-types/15.7.5:
|
/@types/prop-types/15.7.5:
|
||||||
resolution: {integrity: sha512-JCB8C6SnDoQf0cNycqd/35A7MjcnK+ZTqE7judS6o7utxUCg6imJg3QK2qzHKszlTjcj2cn+NwMB2i96ubpj7w==}
|
resolution: {integrity: sha512-JCB8C6SnDoQf0cNycqd/35A7MjcnK+ZTqE7judS6o7utxUCg6imJg3QK2qzHKszlTjcj2cn+NwMB2i96ubpj7w==}
|
||||||
|
@ -7642,6 +7650,10 @@ packages:
|
||||||
/@types/unist/2.0.6:
|
/@types/unist/2.0.6:
|
||||||
resolution: {integrity: sha512-PBjIUxZHOuj0R15/xuwJYjFi+KZdNFrehocChv4g5hu6aFroHue8m0lBP0POdK2nKzbw0cgV1mws8+V/JAcEkQ==}
|
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:
|
/@types/yargs-parser/21.0.0:
|
||||||
resolution: {integrity: sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==}
|
resolution: {integrity: sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==}
|
||||||
dev: true
|
dev: true
|
||||||
|
@ -15157,6 +15169,11 @@ packages:
|
||||||
resolution: {integrity: sha512-B+enWhmw6cjfVC7kS8Pj9pCrKSc5txArRyaYGe088shv/FGWH+0Rjx/xPgtsWfsUtS27FkP697E4DDhgrgoc0Q==}
|
resolution: {integrity: sha512-B+enWhmw6cjfVC7kS8Pj9pCrKSc5txArRyaYGe088shv/FGWH+0Rjx/xPgtsWfsUtS27FkP697E4DDhgrgoc0Q==}
|
||||||
dev: true
|
dev: true
|
||||||
|
|
||||||
|
/which-pm-runs/1.1.0:
|
||||||
|
resolution: {integrity: sha512-n1brCuqClxfFfq/Rb0ICg9giSZqCS+pLtccdag6C2HyufBrh3fBOiy9nb6ggRMvWOVH5GrdJskj5iGTZNxd7SA==}
|
||||||
|
engines: {node: '>=4'}
|
||||||
|
dev: false
|
||||||
|
|
||||||
/which-pm/2.0.0:
|
/which-pm/2.0.0:
|
||||||
resolution: {integrity: sha512-Lhs9Pmyph0p5n5Z3mVnN0yWcbQYUAD7rbQUiMsQxOJ3T57k7RFe35SUwWMf7dsbDZks1uOmw4AecB/JMDj3v/w==}
|
resolution: {integrity: sha512-Lhs9Pmyph0p5n5Z3mVnN0yWcbQYUAD7rbQUiMsQxOJ3T57k7RFe35SUwWMf7dsbDZks1uOmw4AecB/JMDj3v/w==}
|
||||||
engines: {node: '>=8.15'}
|
engines: {node: '>=8.15'}
|
||||||
|
|
Loading…
Reference in a new issue