"use strict"; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); const prompts_1 = __importDefault(require("prompts")); const chalk_1 = __importDefault(require("chalk")); const connector_1 = __importDefault(require("./connector")); const email_validator_1 = __importDefault(require("email-validator")); const messages_1 = __importDefault(require("./messages")); const get_default_project_link_1 = __importDefault(require("./get-default-project-link")); const config_storage_1 = __importDefault(require("../dashboard/config-storage")); const formatting_1 = require("./formatting"); const documentation_url_1 = __importDefault(require("./documentation-url")); const dashboardConnector = new connector_1.default(); const dashboardConfigStorage = new config_storage_1.default(); async function registerInDashboard() { (0, formatting_1.info)(messages_1.default.REGISTRATION_ENTER_EMAIL_INVITATION); const { email } = await (0, prompts_1.default)({ type: 'text', name: 'email', message: messages_1.default.PROMPT_EMAIL_CAPTION, validate: (input) => { if (!email_validator_1.default.validate(input)) return messages_1.default.PROMPT_INVALID_EMAIL; return true; }, }); if (!email) { (0, formatting_1.error)(messages_1.default.REGISTRATION_CANCELLED); return; } const sendEmailResult = await dashboardConnector.sendEmail(email); if (!sendEmailResult.success) { const sendEmailErrorMessage = sendEmailResult.isDashboardError ? sendEmailResult.errorMessage : messages_1.default.REGISTRATION_EMAIL_SENDING_NETWORK_ERROR; (0, formatting_1.error)(sendEmailErrorMessage); return; } (0, formatting_1.info)(messages_1.default.REGISTRATION_EMAIL_SENT); const { token } = await (0, prompts_1.default)({ type: 'text', name: 'token', message: messages_1.default.PROMPT_TOKEN_CAPTION, }); if (!token) { (0, formatting_1.error)(messages_1.default.REGISTRATION_CANCELLED); return; } const validationResult = await dashboardConnector.validateToken(token); if (!validationResult.success) { const validationResultErrorMessage = validationResult.isDashboardError ? validationResult.errorMessage : messages_1.default.TOKEN_VALIDATION_NETWORK_ERROR; (0, formatting_1.error)(validationResultErrorMessage); return; } dashboardConfigStorage.options.sendReport = true; await saveNewToken(token); (0, formatting_1.success)(messages_1.default.REGISTRATION_FINISHED); (0, formatting_1.info)('View test results at:\n' + `${chalk_1.default.underline.blueBright((0, get_default_project_link_1.default)(token))}`); (0, formatting_1.info)(`Run ${chalk_1.default.black.bgWhiteBright('testcafe dashboard off')} to disable this behavior.` + `Learn more at:\n${chalk_1.default.underline.blueBright(documentation_url_1.default)}`); } async function saveNewToken(token) { dashboardConfigStorage.options.token = token; await dashboardConfigStorage.save(); } async function updateDefaultToken() { if (!dashboardConfigStorage.options.sendReport) (0, formatting_1.warning)(messages_1.default.TOKEN_UPDATING_NOT_SEND_REPORT); // NOTE: for the formatting reason (0, formatting_1.info)(''); const { doYouWantToUpdateDefaultToken } = await (0, prompts_1.default)({ type: 'confirm', name: 'doYouWantToUpdateDefaultToken', message: 'Your setup includes a default Dashboard token. Do you want to change it?:', }); if (!doYouWantToUpdateDefaultToken) { (0, formatting_1.error)(messages_1.default.TOKEN_UPDATE_CANCELLED); return; } // NOTE: for the formatting reason (0, formatting_1.info)(''); const { newToken } = await (0, prompts_1.default)({ type: 'text', name: 'newToken', message: 'Enter the new default token value:', }); if (!newToken) { (0, formatting_1.error)(messages_1.default.TOKEN_UPDATE_CANCELLED); return; } const validationResult = await dashboardConnector.validateToken(newToken); if (!validationResult.success) { const validationResultErrorMessage = validationResult.isDashboardError ? validationResult.errorMessage : messages_1.default.TOKEN_VALIDATION_NETWORK_ERROR; (0, formatting_1.error)(validationResultErrorMessage); return; } await saveNewToken(newToken); (0, formatting_1.success)(messages_1.default.TOKEN_UPDATED); } async function setSendReportState(state) { const sendReportAsBoolean = state === 'on'; dashboardConfigStorage.options.sendReport = sendReportAsBoolean; await dashboardConfigStorage.save(); const resultMessage = sendReportAsBoolean ? messages_1.default.SEND_REPORT_STATE_ON : messages_1.default.SEND_REPORT_STATE_OFF; (0, formatting_1.success)(resultMessage); } async function tryToRegisterInDashboard() { (0, formatting_1.info)(messages_1.default.TOKEN_NO_DEFAULT_FOUND); const { launchConfigurationWizard } = await (0, prompts_1.default)({ type: 'confirm', name: 'launchConfigurationWizard', message: 'Do you want to launch the configuration wizard?', initial: true, }); if (!launchConfigurationWizard) { (0, formatting_1.error)(messages_1.default.REGISTRATION_CANCELLED); return; } await registerInDashboard(); } async function default_1(sendReportState) { const storageExists = await dashboardConfigStorage.load(); if (sendReportState !== void 0) { if (storageExists) await setSendReportState(sendReportState); else await tryToRegisterInDashboard(); return; } const thereIsDefaultToken = !!dashboardConfigStorage.options.token; if (thereIsDefaultToken) await updateDefaultToken(); else await registerInDashboard(); } exports.default = default_1; module.exports = exports.default; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/dashboard/index.ts"],"names":[],"mappings":"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","sourcesContent":["import prompts from 'prompts';\nimport chalk from 'chalk';\nimport DashboardConnector from './connector';\nimport emailValidator from 'email-validator';\nimport messages from './messages';\nimport getDefaultProjectLink from './get-default-project-link';\nimport DashboardConfigStorage from '../dashboard/config-storage';\nimport { SendReportState } from './interfaces';\n\nimport {\n    info,\n    warning,\n    error,\n    success,\n} from './formatting';\n\nimport DASHBOARD_DOCUMENTATION_URL from './documentation-url';\n\nconst dashboardConnector     = new DashboardConnector();\nconst dashboardConfigStorage = new DashboardConfigStorage();\n\nasync function registerInDashboard (): Promise<void> {\n    info(messages.REGISTRATION_ENTER_EMAIL_INVITATION);\n\n    const { email } = await prompts({\n        type:     'text',\n        name:     'email',\n        message:  messages.PROMPT_EMAIL_CAPTION,\n        validate: (input: string) => {\n            if (!emailValidator.validate(input))\n                return messages.PROMPT_INVALID_EMAIL;\n\n            return true;\n        },\n    });\n\n    if (!email) {\n        error(messages.REGISTRATION_CANCELLED);\n\n        return;\n    }\n\n    const sendEmailResult = await dashboardConnector.sendEmail(email);\n\n    if (!sendEmailResult.success) {\n        const sendEmailErrorMessage = sendEmailResult.isDashboardError\n            ? sendEmailResult.errorMessage\n            : messages.REGISTRATION_EMAIL_SENDING_NETWORK_ERROR;\n\n        error(sendEmailErrorMessage);\n\n        return;\n    }\n\n    info(messages.REGISTRATION_EMAIL_SENT);\n\n    const { token } = await prompts({\n        type:    'text',\n        name:    'token',\n        message: messages.PROMPT_TOKEN_CAPTION,\n    });\n\n    if (!token) {\n        error(messages.REGISTRATION_CANCELLED);\n\n        return;\n    }\n\n    const validationResult = await dashboardConnector.validateToken(token);\n\n    if (!validationResult.success) {\n        const validationResultErrorMessage = validationResult.isDashboardError\n            ? validationResult.errorMessage\n            : messages.TOKEN_VALIDATION_NETWORK_ERROR;\n\n        error(validationResultErrorMessage);\n\n        return;\n    }\n\n    dashboardConfigStorage.options.sendReport = true;\n\n    await saveNewToken(token);\n\n    success(messages.REGISTRATION_FINISHED);\n\n    info(\n        'View test results at:\\n' +\n        `${chalk.underline.blueBright(getDefaultProjectLink(token))}`\n    );\n\n    info(\n        `Run ${chalk.black.bgWhiteBright('testcafe dashboard off')} to disable this behavior.` +\n        `Learn more at:\\n${chalk.underline.blueBright(DASHBOARD_DOCUMENTATION_URL)}`\n    );\n}\n\nasync function saveNewToken (token: string): Promise<void> {\n    dashboardConfigStorage.options.token = token;\n\n    await dashboardConfigStorage.save();\n}\n\nasync function updateDefaultToken (): Promise<void> {\n    if (!dashboardConfigStorage.options.sendReport)\n        warning(messages.TOKEN_UPDATING_NOT_SEND_REPORT);\n\n    // NOTE: for the formatting reason\n    info('');\n\n    const { doYouWantToUpdateDefaultToken } = await prompts({\n        type:    'confirm',\n        name:    'doYouWantToUpdateDefaultToken',\n        message: 'Your setup includes a default Dashboard token. Do you want to change it?:',\n    });\n\n    if (!doYouWantToUpdateDefaultToken) {\n        error(messages.TOKEN_UPDATE_CANCELLED);\n\n        return;\n    }\n\n    // NOTE: for the formatting reason\n    info('');\n\n    const { newToken } = await prompts({\n        type:    'text',\n        name:    'newToken',\n        message: 'Enter the new default token value:',\n    });\n\n    if (!newToken) {\n        error(messages.TOKEN_UPDATE_CANCELLED);\n\n        return;\n    }\n\n    const validationResult = await dashboardConnector.validateToken(newToken);\n\n    if (!validationResult.success) {\n        const validationResultErrorMessage = validationResult.isDashboardError\n            ? validationResult.errorMessage\n            : messages.TOKEN_VALIDATION_NETWORK_ERROR;\n\n        error(validationResultErrorMessage);\n\n        return;\n    }\n\n    await saveNewToken(newToken);\n\n    success(messages.TOKEN_UPDATED);\n}\n\nasync function setSendReportState (state: SendReportState): Promise<void> {\n    const sendReportAsBoolean = state === 'on';\n\n    dashboardConfigStorage.options.sendReport = sendReportAsBoolean;\n\n    await dashboardConfigStorage.save();\n\n    const resultMessage = sendReportAsBoolean ? messages.SEND_REPORT_STATE_ON : messages.SEND_REPORT_STATE_OFF;\n\n    success(resultMessage);\n}\n\nasync function tryToRegisterInDashboard (): Promise<void> {\n    info(messages.TOKEN_NO_DEFAULT_FOUND);\n\n    const { launchConfigurationWizard } = await prompts({\n        type:    'confirm',\n        name:    'launchConfigurationWizard',\n        message: 'Do you want to launch the configuration wizard?',\n        initial: true,\n    });\n\n    if (!launchConfigurationWizard) {\n        error(messages.REGISTRATION_CANCELLED);\n\n        return;\n    }\n\n    await registerInDashboard();\n}\n\nexport default async function (sendReportState: SendReportState): Promise<void> {\n    const storageExists = await dashboardConfigStorage.load();\n\n    if (sendReportState !== void 0) {\n        if (storageExists)\n            await setSendReportState(sendReportState);\n        else\n            await tryToRegisterInDashboard();\n\n        return;\n    }\n\n    const thereIsDefaultToken = !!dashboardConfigStorage.options.token;\n\n    if (thereIsDefaultToken)\n        await updateDefaultToken();\n    else\n        await registerInDashboard();\n}\n"]}