mirror of
https://github.com/strapi/strapi.git
synced 2025-08-10 17:58:07 +00:00

Create starter CLI Add spaces option Extract project basename Add starter shortcut Refactor git init commit Replace concurrently with npm-run-all Move fetch repo function to dedicated file Allow shortcut to accept external org repo Fix package config & readme Fix versions Add task prefixes Update readme [Starter CLI] error handling (#9600) * Display error message + help for missing arguments * Add cleaner error messages * Bump commander from v6.1.0 to v7.1.0 * Capture and log errors from commander * Simplify cli argument errors * Provide more human readable error messages * Replace throw with console log * Add logger Add starter tracking Add wrapper for tracking keys Update root config Keep template in scope root fix strapi config Fix open frontend Remove open-cli Update for rename frontend->starter update description Update tracking Fix tests fix e2e tests Make sure packageJsonStrapi does not override unwanted keys & make it optional to avoid errors simplify metadata strapi Allow stater or frontend folder for smooth migration of existing starters Udpate dep Handle error
132 lines
2.9 KiB
JavaScript
132 lines
2.9 KiB
JavaScript
'use strict';
|
|
|
|
const os = require('os');
|
|
const _ = require('lodash');
|
|
const fetch = require('node-fetch');
|
|
const sentry = require('@sentry/node');
|
|
|
|
/**
|
|
* Add properties from the package.json strapi key in the metadata
|
|
* @param {object} metadata
|
|
* @param {object} scope
|
|
*/
|
|
function addPackageJsonStrapiMetadata(metadata, scope) {
|
|
const { packageJsonStrapi = {} } = scope;
|
|
|
|
return _.defaults(metadata, packageJsonStrapi);
|
|
}
|
|
|
|
async function captureException(error) {
|
|
try {
|
|
sentry.captureException(error);
|
|
await sentry.flush();
|
|
} catch (err) {
|
|
/** ignore errors*/
|
|
return Promise.resolve();
|
|
}
|
|
}
|
|
|
|
async function captureError(message) {
|
|
try {
|
|
sentry.captureMessage(message, 'error');
|
|
await sentry.flush();
|
|
} catch (err) {
|
|
/** ignore errors*/
|
|
return Promise.resolve();
|
|
}
|
|
}
|
|
|
|
function captureStderr(name, error) {
|
|
if (error && error.stderr && error.stderr.trim() !== '') {
|
|
error.stderr
|
|
.trim()
|
|
.split('\n')
|
|
.forEach(line => {
|
|
sentry.addBreadcrumb({
|
|
category: 'stderr',
|
|
message: line,
|
|
level: 'error',
|
|
});
|
|
});
|
|
}
|
|
|
|
return captureError(name);
|
|
}
|
|
|
|
function trackEvent(event, body) {
|
|
try {
|
|
return fetch('https://analytics.strapi.io/track', {
|
|
method: 'POST',
|
|
body: JSON.stringify({
|
|
event,
|
|
...body,
|
|
}),
|
|
timeout: 1000,
|
|
headers: { 'Content-Type': 'application/json' },
|
|
}).catch(() => {});
|
|
} catch (err) {
|
|
/** ignore errors*/
|
|
return Promise.resolve();
|
|
}
|
|
}
|
|
|
|
function trackError({ scope, error }) {
|
|
const { uuid } = scope;
|
|
|
|
const properties = {
|
|
error: typeof error == 'string' ? error : error && error.message,
|
|
os: os.type(),
|
|
platform: os.platform(),
|
|
release: os.release(),
|
|
version: scope.strapiVersion,
|
|
nodeVersion: process.version,
|
|
docker: scope.docker,
|
|
useYarn: scope.useYarn,
|
|
};
|
|
|
|
try {
|
|
return trackEvent('didNotCreateProject', {
|
|
uuid,
|
|
deviceId: scope.deviceId,
|
|
properties: addPackageJsonStrapiMetadata(properties, scope),
|
|
});
|
|
} catch (err) {
|
|
/** ignore errors*/
|
|
return Promise.resolve();
|
|
}
|
|
}
|
|
|
|
function trackUsage({ event, scope, error }) {
|
|
const { uuid } = scope;
|
|
|
|
const properties = {
|
|
error: typeof error == 'string' ? error : error && error.message,
|
|
os: os.type(),
|
|
os_platform: os.platform(),
|
|
os_release: os.release(),
|
|
node_version: process.version,
|
|
version: scope.strapiVersion,
|
|
docker: scope.docker,
|
|
useYarn: scope.useYarn.toString(),
|
|
noRun: (scope.runQuickstartApp !== true).toString(),
|
|
};
|
|
|
|
try {
|
|
return trackEvent(event, {
|
|
uuid: uuid,
|
|
deviceId: scope.deviceId,
|
|
properties: addPackageJsonStrapiMetadata(properties, scope),
|
|
});
|
|
} catch (err) {
|
|
/** ignore errors*/
|
|
return Promise.resolve();
|
|
}
|
|
}
|
|
|
|
module.exports = {
|
|
trackError,
|
|
trackUsage,
|
|
captureException,
|
|
captureStderr,
|
|
};
|