File: /var/www/vhost/disk-apps/pwa.sports-crowd.com/node_modules/@angular/cli/src/analytics/analytics.js
"use strict";
/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.getAnalyticsInfoString = exports.getAnalyticsUserId = exports.promptAnalytics = exports.setAnalyticsConfig = exports.isPackageNameSafeForAnalytics = exports.analyticsPackageSafelist = void 0;
const core_1 = require("@angular-devkit/core");
const crypto_1 = require("crypto");
const color_1 = require("../utilities/color");
const config_1 = require("../utilities/config");
const environment_options_1 = require("../utilities/environment-options");
const tty_1 = require("../utilities/tty");
/* eslint-disable no-console */
/**
* This is the ultimate safelist for checking if a package name is safe to report to analytics.
*/
exports.analyticsPackageSafelist = [
/^@angular\//,
/^@angular-devkit\//,
/^@nguniversal\//,
'@schematics/angular',
];
function isPackageNameSafeForAnalytics(name) {
return exports.analyticsPackageSafelist.some((pattern) => {
if (typeof pattern == 'string') {
return pattern === name;
}
else {
return pattern.test(name);
}
});
}
exports.isPackageNameSafeForAnalytics = isPackageNameSafeForAnalytics;
/**
* Set analytics settings. This does not work if the user is not inside a project.
* @param global Which config to use. "global" for user-level, and "local" for project-level.
* @param value Either a user ID, true to generate a new User ID, or false to disable analytics.
*/
async function setAnalyticsConfig(global, value) {
var _a;
const level = global ? 'global' : 'local';
const workspace = await (0, config_1.getWorkspace)(level);
if (!workspace) {
throw new Error(`Could not find ${level} workspace.`);
}
const cli = ((_a = workspace.extensions)['cli'] ?? (_a['cli'] = {}));
if (!workspace || !core_1.json.isJsonObject(cli)) {
throw new Error(`Invalid config found at ${workspace.filePath}. CLI should be an object.`);
}
cli.analytics = value === true ? (0, crypto_1.randomUUID)() : value;
await workspace.save();
}
exports.setAnalyticsConfig = setAnalyticsConfig;
/**
* Prompt the user for usage gathering permission.
* @param force Whether to ask regardless of whether or not the user is using an interactive shell.
* @return Whether or not the user was shown a prompt.
*/
async function promptAnalytics(context, global, force = false) {
const level = global ? 'global' : 'local';
const workspace = await (0, config_1.getWorkspace)(level);
if (!workspace) {
throw new Error(`Could not find a ${level} workspace. Are you in a project?`);
}
if (force || (0, tty_1.isTTY)()) {
const { prompt } = await Promise.resolve().then(() => __importStar(require('inquirer')));
const answers = await prompt([
{
type: 'confirm',
name: 'analytics',
message: core_1.tags.stripIndents `
Would you like to share pseudonymous usage data about this project with the Angular Team
at Google under Google's Privacy Policy at https://policies.google.com/privacy. For more
details and how to change this setting, see https://angular.io/analytics.
`,
default: false,
},
]);
await setAnalyticsConfig(global, answers.analytics);
if (answers.analytics) {
console.log('');
console.log(core_1.tags.stripIndent `
Thank you for sharing pseudonymous usage data. Should you change your mind, the following
command will disable this feature entirely:
${color_1.colors.yellow(`ng analytics disable${global ? ' --global' : ''}`)}
`);
console.log('');
}
process.stderr.write(await getAnalyticsInfoString(context));
return true;
}
return false;
}
exports.promptAnalytics = promptAnalytics;
/**
* Get the analytics user id.
*
* @returns
* - `string` user id.
* - `false` when disabled.
* - `undefined` when not configured.
*/
async function getAnalyticsUserIdForLevel(level) {
if (environment_options_1.analyticsDisabled) {
return false;
}
const workspace = await (0, config_1.getWorkspace)(level);
const analyticsConfig = workspace?.getCli()?.['analytics'];
if (analyticsConfig === false) {
return false;
}
else if (analyticsConfig === undefined || analyticsConfig === null) {
return undefined;
}
else {
if (typeof analyticsConfig == 'string') {
return analyticsConfig;
}
else if (typeof analyticsConfig == 'object' && typeof analyticsConfig['uid'] == 'string') {
return analyticsConfig['uid'];
}
return undefined;
}
}
async function getAnalyticsUserId(context, skipPrompt = false) {
const { workspace } = context;
// Global config takes precedence over local config only for the disabled check.
// IE:
// global: disabled & local: enabled = disabled
// global: id: 123 & local: id: 456 = 456
// check global
const globalConfig = await getAnalyticsUserIdForLevel('global');
if (globalConfig === false) {
return undefined;
}
// Not disabled globally, check locally or not set globally and command is run outside of workspace example: `ng new`
if (workspace || globalConfig === undefined) {
const level = workspace ? 'local' : 'global';
let localOrGlobalConfig = await getAnalyticsUserIdForLevel(level);
if (localOrGlobalConfig === undefined) {
if (!skipPrompt) {
// config is unset, prompt user.
// TODO: This should honor the `no-interactive` option.
// It is currently not an `ng` option but rather only an option for specific commands.
// The concept of `ng`-wide options are needed to cleanly handle this.
await promptAnalytics(context, !workspace /** global */);
localOrGlobalConfig = await getAnalyticsUserIdForLevel(level);
}
}
if (localOrGlobalConfig === false) {
return undefined;
}
else if (typeof localOrGlobalConfig === 'string') {
return localOrGlobalConfig;
}
}
return globalConfig;
}
exports.getAnalyticsUserId = getAnalyticsUserId;
function analyticsConfigValueToHumanFormat(value) {
if (value === false) {
return 'disabled';
}
else if (typeof value === 'string' || value === true) {
return 'enabled';
}
else {
return 'not set';
}
}
async function getAnalyticsInfoString(context) {
const analyticsInstance = await getAnalyticsUserId(context, true /** skipPrompt */);
const { globalConfiguration, workspace: localWorkspace } = context;
const globalSetting = globalConfiguration?.getCli()?.['analytics'];
const localSetting = localWorkspace?.getCli()?.['analytics'];
return (core_1.tags.stripIndents `
Global setting: ${analyticsConfigValueToHumanFormat(globalSetting)}
Local setting: ${localWorkspace
? analyticsConfigValueToHumanFormat(localSetting)
: 'No local workspace configuration file.'}
Effective status: ${analyticsInstance ? 'enabled' : 'disabled'}
` + '\n');
}
exports.getAnalyticsInfoString = getAnalyticsInfoString;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"analytics.js","sourceRoot":"","sources":["../../../../../../../../packages/angular/cli/src/analytics/analytics.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { json, tags } from '@angular-devkit/core';\nimport { randomUUID } from 'crypto';\nimport type { CommandContext } from '../command-builder/command-module';\nimport { colors } from '../utilities/color';\nimport { getWorkspace } from '../utilities/config';\nimport { analyticsDisabled } from '../utilities/environment-options';\nimport { isTTY } from '../utilities/tty';\n\n/* eslint-disable no-console */\n\n/**\n * This is the ultimate safelist for checking if a package name is safe to report to analytics.\n */\nexport const analyticsPackageSafelist = [\n  /^@angular\\//,\n  /^@angular-devkit\\//,\n  /^@nguniversal\\//,\n  '@schematics/angular',\n];\n\nexport function isPackageNameSafeForAnalytics(name: string): boolean {\n  return analyticsPackageSafelist.some((pattern) => {\n    if (typeof pattern == 'string') {\n      return pattern === name;\n    } else {\n      return pattern.test(name);\n    }\n  });\n}\n\n/**\n * Set analytics settings. This does not work if the user is not inside a project.\n * @param global Which config to use. \"global\" for user-level, and \"local\" for project-level.\n * @param value Either a user ID, true to generate a new User ID, or false to disable analytics.\n */\nexport async function setAnalyticsConfig(global: boolean, value: string | boolean): Promise<void> {\n  const level = global ? 'global' : 'local';\n  const workspace = await getWorkspace(level);\n  if (!workspace) {\n    throw new Error(`Could not find ${level} workspace.`);\n  }\n\n  const cli = (workspace.extensions['cli'] ??= {});\n  if (!workspace || !json.isJsonObject(cli)) {\n    throw new Error(`Invalid config found at ${workspace.filePath}. CLI should be an object.`);\n  }\n\n  cli.analytics = value === true ? randomUUID() : value;\n  await workspace.save();\n}\n\n/**\n * Prompt the user for usage gathering permission.\n * @param force Whether to ask regardless of whether or not the user is using an interactive shell.\n * @return Whether or not the user was shown a prompt.\n */\nexport async function promptAnalytics(\n  context: CommandContext,\n  global: boolean,\n  force = false,\n): Promise<boolean> {\n  const level = global ? 'global' : 'local';\n  const workspace = await getWorkspace(level);\n  if (!workspace) {\n    throw new Error(`Could not find a ${level} workspace. Are you in a project?`);\n  }\n\n  if (force || isTTY()) {\n    const { prompt } = await import('inquirer');\n    const answers = await prompt<{ analytics: boolean }>([\n      {\n        type: 'confirm',\n        name: 'analytics',\n        message: tags.stripIndents`\n           Would you like to share pseudonymous usage data about this project with the Angular Team\n           at Google under Google's Privacy Policy at https://policies.google.com/privacy. For more\n           details and how to change this setting, see https://angular.io/analytics.\n\n         `,\n        default: false,\n      },\n    ]);\n\n    await setAnalyticsConfig(global, answers.analytics);\n\n    if (answers.analytics) {\n      console.log('');\n      console.log(\n        tags.stripIndent`\n         Thank you for sharing pseudonymous usage data. Should you change your mind, the following\n         command will disable this feature entirely:\n\n             ${colors.yellow(`ng analytics disable${global ? ' --global' : ''}`)}\n       `,\n      );\n      console.log('');\n    }\n\n    process.stderr.write(await getAnalyticsInfoString(context));\n\n    return true;\n  }\n\n  return false;\n}\n\n/**\n * Get the analytics user id.\n *\n * @returns\n * - `string` user id.\n * - `false` when disabled.\n * - `undefined` when not configured.\n */\nasync function getAnalyticsUserIdForLevel(\n  level: 'local' | 'global',\n): Promise<string | false | undefined> {\n  if (analyticsDisabled) {\n    return false;\n  }\n\n  const workspace = await getWorkspace(level);\n  const analyticsConfig: string | undefined | null | { uid?: string } | boolean =\n    workspace?.getCli()?.['analytics'];\n\n  if (analyticsConfig === false) {\n    return false;\n  } else if (analyticsConfig === undefined || analyticsConfig === null) {\n    return undefined;\n  } else {\n    if (typeof analyticsConfig == 'string') {\n      return analyticsConfig;\n    } else if (typeof analyticsConfig == 'object' && typeof analyticsConfig['uid'] == 'string') {\n      return analyticsConfig['uid'];\n    }\n\n    return undefined;\n  }\n}\n\nexport async function getAnalyticsUserId(\n  context: CommandContext,\n  skipPrompt = false,\n): Promise<string | undefined> {\n  const { workspace } = context;\n  // Global config takes precedence over local config only for the disabled check.\n  // IE:\n  // global: disabled & local: enabled = disabled\n  // global: id: 123 & local: id: 456 = 456\n\n  // check global\n  const globalConfig = await getAnalyticsUserIdForLevel('global');\n  if (globalConfig === false) {\n    return undefined;\n  }\n\n  // Not disabled globally, check locally or not set globally and command is run outside of workspace example: `ng new`\n  if (workspace || globalConfig === undefined) {\n    const level = workspace ? 'local' : 'global';\n    let localOrGlobalConfig = await getAnalyticsUserIdForLevel(level);\n    if (localOrGlobalConfig === undefined) {\n      if (!skipPrompt) {\n        // config is unset, prompt user.\n        // TODO: This should honor the `no-interactive` option.\n        // It is currently not an `ng` option but rather only an option for specific commands.\n        // The concept of `ng`-wide options are needed to cleanly handle this.\n        await promptAnalytics(context, !workspace /** global */);\n        localOrGlobalConfig = await getAnalyticsUserIdForLevel(level);\n      }\n    }\n\n    if (localOrGlobalConfig === false) {\n      return undefined;\n    } else if (typeof localOrGlobalConfig === 'string') {\n      return localOrGlobalConfig;\n    }\n  }\n\n  return globalConfig;\n}\n\nfunction analyticsConfigValueToHumanFormat(value: unknown): 'enabled' | 'disabled' | 'not set' {\n  if (value === false) {\n    return 'disabled';\n  } else if (typeof value === 'string' || value === true) {\n    return 'enabled';\n  } else {\n    return 'not set';\n  }\n}\n\nexport async function getAnalyticsInfoString(context: CommandContext): Promise<string> {\n  const analyticsInstance = await getAnalyticsUserId(context, true /** skipPrompt */);\n\n  const { globalConfiguration, workspace: localWorkspace } = context;\n  const globalSetting = globalConfiguration?.getCli()?.['analytics'];\n  const localSetting = localWorkspace?.getCli()?.['analytics'];\n\n  return (\n    tags.stripIndents`\n     Global setting: ${analyticsConfigValueToHumanFormat(globalSetting)}\n     Local setting: ${\n       localWorkspace\n         ? analyticsConfigValueToHumanFormat(localSetting)\n         : 'No local workspace configuration file.'\n     }\n     Effective status: ${analyticsInstance ? 'enabled' : 'disabled'}\n   ` + '\\n'\n  );\n}\n"]}