145 lines
19 KiB
JavaScript
145 lines
19 KiB
JavaScript
"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"]}
|