HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux ip-172-31-42-149 5.15.0-1084-aws #91~20.04.1-Ubuntu SMP Fri May 2 07:00:04 UTC 2025 aarch64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
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"]}