@hubspot/cli 6.2.0 → 6.2.2-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +12 -95
- package/bin/cli.d.ts +2 -0
- package/bin/cli.js +107 -128
- package/commands/accounts/clean.d.ts +1 -0
- package/commands/accounts/clean.js +82 -116
- package/commands/accounts/info.d.ts +1 -0
- package/commands/accounts/info.js +32 -43
- package/commands/accounts/list.d.ts +1 -0
- package/commands/accounts/list.js +65 -92
- package/commands/accounts/remove.d.ts +1 -0
- package/commands/accounts/remove.js +43 -73
- package/commands/accounts/rename.d.ts +1 -0
- package/commands/accounts/rename.js +26 -41
- package/commands/accounts/use.d.ts +1 -0
- package/commands/accounts/use.js +36 -57
- package/commands/accounts.d.ts +1 -0
- package/commands/accounts.js +16 -18
- package/commands/auth.d.ts +1 -0
- package/commands/auth.js +133 -200
- package/commands/cms/convertFields.d.ts +1 -0
- package/commands/cms/convertFields.js +66 -81
- package/commands/cms/lighthouseScore.d.ts +1 -0
- package/commands/cms/lighthouseScore.js +236 -298
- package/commands/cms/reactModules.d.ts +1 -0
- package/commands/cms/reactModules.js +46 -53
- package/commands/cms.d.ts +1 -0
- package/commands/cms.js +11 -13
- package/commands/config/set.d.ts +1 -0
- package/commands/config/set.js +64 -79
- package/commands/config.d.ts +1 -0
- package/commands/config.js +7 -9
- package/commands/create/api-sample.d.ts +1 -0
- package/commands/create/api-sample.js +54 -74
- package/commands/create/app.d.ts +1 -0
- package/commands/create/app.js +8 -7
- package/commands/create/function.d.ts +1 -0
- package/commands/create/function.js +15 -14
- package/commands/create/index.d.ts +1 -0
- package/commands/create/index.js +12 -9
- package/commands/create/module.d.ts +1 -0
- package/commands/create/module.js +21 -19
- package/commands/create/react-app.d.ts +1 -0
- package/commands/create/react-app.js +7 -6
- package/commands/create/template.d.ts +1 -0
- package/commands/create/template.js +23 -24
- package/commands/create/vue-app.d.ts +1 -0
- package/commands/create/vue-app.js +7 -6
- package/commands/create/webpack-serverless.d.ts +1 -0
- package/commands/create/webpack-serverless.js +7 -6
- package/commands/create/website-theme.d.ts +1 -0
- package/commands/create/website-theme.js +15 -15
- package/commands/create.d.ts +24 -0
- package/commands/create.js +65 -80
- package/commands/customObject/create.d.ts +1 -0
- package/commands/customObject/create.js +33 -47
- package/commands/customObject/schema/create.d.ts +1 -0
- package/commands/customObject/schema/create.js +42 -67
- package/commands/customObject/schema/delete.d.ts +1 -0
- package/commands/customObject/schema/delete.js +28 -39
- package/commands/customObject/schema/fetch-all.d.ts +1 -0
- package/commands/customObject/schema/fetch-all.js +30 -39
- package/commands/customObject/schema/fetch.d.ts +1 -0
- package/commands/customObject/schema/fetch.js +48 -63
- package/commands/customObject/schema/list.d.ts +1 -0
- package/commands/customObject/schema/list.js +14 -17
- package/commands/customObject/schema/update.d.ts +1 -0
- package/commands/customObject/schema/update.js +46 -72
- package/commands/customObject/schema.d.ts +1 -0
- package/commands/customObject/schema.js +12 -12
- package/commands/customObject.d.ts +1 -0
- package/commands/customObject.js +14 -22
- package/commands/feedback.d.ts +1 -0
- package/commands/feedback.js +25 -33
- package/commands/fetch.d.ts +1 -0
- package/commands/fetch.js +53 -78
- package/commands/filemanager/fetch.d.ts +1 -0
- package/commands/filemanager/fetch.js +38 -56
- package/commands/filemanager/upload.d.ts +1 -0
- package/commands/filemanager/upload.js +88 -128
- package/commands/filemanager.d.ts +1 -0
- package/commands/filemanager.js +12 -18
- package/commands/functions/deploy.d.ts +1 -0
- package/commands/functions/deploy.js +76 -99
- package/commands/functions/list.d.ts +1 -0
- package/commands/functions/list.js +41 -48
- package/commands/functions/server.d.ts +1 -0
- package/commands/functions/server.js +50 -65
- package/commands/functions.d.ts +1 -0
- package/commands/functions.js +13 -15
- package/commands/hubdb/clear.d.ts +1 -0
- package/commands/hubdb/clear.js +37 -56
- package/commands/hubdb/create.d.ts +1 -0
- package/commands/hubdb/create.js +34 -57
- package/commands/hubdb/delete.d.ts +1 -0
- package/commands/hubdb/delete.js +29 -44
- package/commands/hubdb/fetch.d.ts +1 -0
- package/commands/hubdb/fetch.js +30 -46
- package/commands/hubdb.d.ts +1 -0
- package/commands/hubdb.js +12 -14
- package/commands/init.d.ts +1 -0
- package/commands/init.js +103 -160
- package/commands/lint.d.ts +1 -0
- package/commands/lint.js +34 -45
- package/commands/list.d.ts +1 -0
- package/commands/list.js +74 -101
- package/commands/logs.d.ts +1 -0
- package/commands/logs.js +98 -121
- package/commands/module/marketplace-validate.d.ts +1 -0
- package/commands/module/marketplace-validate.js +32 -57
- package/commands/module.d.ts +1 -0
- package/commands/module.js +7 -9
- package/commands/mv.d.ts +1 -0
- package/commands/mv.js +53 -71
- package/commands/open.d.ts +1 -0
- package/commands/open.js +48 -62
- package/commands/project/add.d.ts +1 -0
- package/commands/project/add.js +47 -70
- package/commands/project/cloneApp.d.ts +1 -0
- package/commands/project/cloneApp.js +119 -180
- package/commands/project/create.d.ts +1 -0
- package/commands/project/create.js +49 -81
- package/commands/project/deploy.d.ts +1 -0
- package/commands/project/deploy.js +105 -182
- package/commands/project/dev.d.ts +1 -0
- package/commands/project/dev.js +126 -227
- package/commands/project/download.d.ts +1 -0
- package/commands/project/download.js +73 -123
- package/commands/project/installDeps.d.ts +1 -0
- package/commands/project/installDeps.js +52 -59
- package/commands/project/listBuilds.d.ts +1 -0
- package/commands/project/listBuilds.js +97 -139
- package/commands/project/logs.d.ts +1 -0
- package/commands/project/logs.js +86 -128
- package/commands/project/migrateApp.d.ts +1 -0
- package/commands/project/migrateApp.js +158 -248
- package/commands/project/open.d.ts +1 -0
- package/commands/project/open.js +44 -68
- package/commands/project/upload.d.ts +1 -0
- package/commands/project/upload.js +72 -116
- package/commands/project/watch.d.ts +1 -0
- package/commands/project/watch.js +94 -152
- package/commands/project.d.ts +1 -0
- package/commands/project.js +21 -23
- package/commands/remove.d.ts +1 -0
- package/commands/remove.js +28 -43
- package/commands/sandbox/create.d.ts +1 -0
- package/commands/sandbox/create.js +143 -187
- package/commands/sandbox/delete.d.ts +1 -0
- package/commands/sandbox/delete.js +166 -221
- package/commands/sandbox.d.ts +1 -0
- package/commands/sandbox.js +10 -12
- package/commands/secrets/addSecret.d.ts +1 -0
- package/commands/secrets/addSecret.js +34 -52
- package/commands/secrets/deleteSecret.d.ts +1 -0
- package/commands/secrets/deleteSecret.js +33 -50
- package/commands/secrets/listSecrets.d.ts +1 -0
- package/commands/secrets/listSecrets.js +28 -42
- package/commands/secrets/updateSecret.d.ts +1 -0
- package/commands/secrets/updateSecret.js +35 -53
- package/commands/secrets.d.ts +1 -0
- package/commands/secrets.js +12 -13
- package/commands/theme/generate-selectors.d.ts +1 -0
- package/commands/theme/generate-selectors.js +129 -192
- package/commands/theme/marketplace-validate.d.ts +1 -0
- package/commands/theme/marketplace-validate.js +32 -57
- package/commands/theme/preview.d.ts +1 -0
- package/commands/theme/preview.js +170 -195
- package/commands/theme.d.ts +1 -0
- package/commands/theme.js +9 -11
- package/commands/upload.d.ts +1 -0
- package/commands/upload.js +199 -287
- package/commands/watch.d.ts +1 -0
- package/commands/watch.js +128 -172
- package/lang/en.lyaml +2 -3
- package/lib/DevServerManager.d.ts +1 -0
- package/lib/DevServerManager.js +99 -124
- package/lib/LocalDevManager.d.ts +1 -0
- package/lib/LocalDevManager.js +322 -490
- package/lib/accountTypes.d.ts +7 -0
- package/lib/accountTypes.js +32 -34
- package/lib/buildAccount.d.ts +1 -0
- package/lib/buildAccount.js +132 -179
- package/lib/commonOpts.d.ts +1 -0
- package/lib/commonOpts.js +60 -91
- package/lib/configOptions.d.ts +1 -0
- package/lib/configOptions.js +110 -0
- package/lib/constants.d.ts +84 -0
- package/lib/constants.js +64 -91
- package/lib/debugInfo.d.ts +1 -0
- package/lib/debugInfo.js +14 -13
- package/lib/dependencyManagement.d.ts +1 -0
- package/lib/dependencyManagement.js +92 -132
- package/lib/developerTestAccounts.d.ts +1 -0
- package/lib/developerTestAccounts.js +67 -91
- package/lib/enums/exitCodes.d.ts +5 -0
- package/lib/enums/exitCodes.js +7 -8
- package/lib/environment.d.ts +1 -0
- package/lib/environment.js +13 -14
- package/lib/errorHandlers/index.d.ts +1 -0
- package/lib/errorHandlers/index.js +66 -80
- package/lib/errorHandlers/suppressError.d.ts +1 -0
- package/lib/errorHandlers/suppressError.js +66 -106
- package/lib/filesystem.d.ts +2 -0
- package/lib/filesystem.js +22 -28
- package/lib/generate-selectors.d.ts +1 -0
- package/lib/generate-selectors.js +102 -138
- package/lib/hasFeature.d.ts +1 -0
- package/lib/hasFeature.js +8 -15
- package/lib/hasFlag.d.ts +1 -0
- package/lib/hasFlag.js +13 -13
- package/lib/hublValidate.d.ts +2 -0
- package/lib/hublValidate.js +28 -28
- package/lib/interpolation.d.ts +1 -0
- package/lib/interpolation.js +50 -92
- package/lib/interpolationHelpers.d.ts +10 -0
- package/lib/interpolationHelpers.js +30 -22
- package/lib/lang.d.ts +1 -0
- package/lib/lang.js +52 -78
- package/lib/links.d.ts +1 -0
- package/lib/links.js +94 -114
- package/lib/localDev.d.ts +1 -0
- package/lib/localDev.js +285 -433
- package/lib/marketplace-validate.d.ts +1 -0
- package/lib/marketplace-validate.js +105 -126
- package/lib/oauth.d.ts +1 -0
- package/lib/oauth.js +64 -78
- package/lib/polling.d.ts +1 -0
- package/lib/polling.js +26 -26
- package/lib/process.d.ts +1 -0
- package/lib/process.js +41 -53
- package/lib/projectLogsManager.d.ts +1 -0
- package/lib/projectLogsManager.js +78 -130
- package/lib/projectStructure.d.ts +1 -0
- package/lib/projectStructure.js +89 -109
- package/lib/projects.d.ts +1 -0
- package/lib/projects.js +595 -958
- package/lib/projectsWatch.d.ts +1 -0
- package/lib/projectsWatch.js +127 -228
- package/lib/prompts/accountNamePrompt.d.ts +1 -0
- package/lib/prompts/accountNamePrompt.js +60 -65
- package/lib/prompts/accountsPrompt.d.ts +1 -0
- package/lib/prompts/accountsPrompt.js +33 -37
- package/lib/prompts/activeInstallConfirmationPrompt.d.ts +1 -0
- package/lib/prompts/activeInstallConfirmationPrompt.js +13 -13
- package/lib/prompts/cleanUploadPrompt.d.ts +1 -0
- package/lib/prompts/cleanUploadPrompt.js +13 -13
- package/lib/prompts/cmsFieldPrompt.d.ts +1 -0
- package/lib/prompts/cmsFieldPrompt.js +37 -39
- package/lib/prompts/createApiSamplePrompt.d.ts +1 -0
- package/lib/prompts/createApiSamplePrompt.js +49 -52
- package/lib/prompts/createFunctionPrompt.d.ts +1 -0
- package/lib/prompts/createFunctionPrompt.js +57 -56
- package/lib/prompts/createModulePrompt.d.ts +1 -0
- package/lib/prompts/createModulePrompt.js +47 -50
- package/lib/prompts/createProjectPrompt.d.ts +1 -0
- package/lib/prompts/createProjectPrompt.js +95 -129
- package/lib/prompts/createTemplatePrompt.d.ts +1 -0
- package/lib/prompts/createTemplatePrompt.js +18 -19
- package/lib/prompts/deployBuildIdPrompt.d.ts +1 -0
- package/lib/prompts/deployBuildIdPrompt.js +15 -15
- package/lib/prompts/downloadProjectPrompt.d.ts +1 -0
- package/lib/prompts/downloadProjectPrompt.js +39 -41
- package/lib/prompts/feedbackPrompt.d.ts +1 -0
- package/lib/prompts/feedbackPrompt.js +29 -30
- package/lib/prompts/folderOverwritePrompt.d.ts +1 -0
- package/lib/prompts/folderOverwritePrompt.js +10 -10
- package/lib/prompts/installPublicAppPrompt.d.ts +1 -0
- package/lib/prompts/installPublicAppPrompt.js +29 -42
- package/lib/prompts/personalAccessKeyPrompt.d.ts +1 -0
- package/lib/prompts/personalAccessKeyPrompt.js +104 -110
- package/lib/prompts/previewPrompt.d.ts +1 -0
- package/lib/prompts/previewPrompt.js +46 -47
- package/lib/prompts/projectAddPrompt.d.ts +1 -0
- package/lib/prompts/projectAddPrompt.js +37 -38
- package/lib/prompts/projectDevTargetAccountPrompt.d.ts +1 -0
- package/lib/prompts/projectDevTargetAccountPrompt.js +150 -193
- package/lib/prompts/projectNamePrompt.d.ts +1 -0
- package/lib/prompts/projectNamePrompt.js +25 -25
- package/lib/prompts/projectsLogsPrompt.d.ts +1 -0
- package/lib/prompts/projectsLogsPrompt.js +21 -27
- package/lib/prompts/promptUtils.d.ts +1 -0
- package/lib/prompts/promptUtils.js +17 -17
- package/lib/prompts/sandboxesPrompt.d.ts +1 -0
- package/lib/prompts/sandboxesPrompt.js +50 -59
- package/lib/prompts/secretPrompt.d.ts +1 -0
- package/lib/prompts/secretPrompt.js +15 -16
- package/lib/prompts/selectPublicAppPrompt.d.ts +1 -0
- package/lib/prompts/selectPublicAppPrompt.js +58 -82
- package/lib/prompts/setAsDefaultAccountPrompt.d.ts +1 -0
- package/lib/prompts/setAsDefaultAccountPrompt.js +19 -24
- package/lib/prompts/uploadPrompt.d.ts +1 -0
- package/lib/prompts/uploadPrompt.js +30 -30
- package/lib/regex.d.ts +1 -0
- package/lib/regex.js +4 -5
- package/lib/sandboxSync.d.ts +1 -0
- package/lib/sandboxSync.js +100 -166
- package/lib/sandboxes.d.ts +1 -0
- package/lib/sandboxes.js +201 -316
- package/lib/schema.d.ts +3 -0
- package/lib/schema.js +29 -33
- package/lib/serverlessLogs.d.ts +1 -0
- package/lib/serverlessLogs.js +131 -173
- package/lib/ui/SpinniesManager.d.ts +1 -0
- package/lib/ui/SpinniesManager.js +198 -254
- package/lib/ui/git.d.ts +1 -0
- package/lib/ui/git.js +20 -19
- package/lib/ui/index.d.ts +1 -0
- package/lib/ui/index.js +117 -167
- package/lib/ui/serverlessFunctionLogs.d.ts +1 -0
- package/lib/ui/serverlessFunctionLogs.js +53 -70
- package/lib/ui/spinniesUtils.d.ts +1 -0
- package/lib/ui/spinniesUtils.js +111 -133
- package/lib/ui/supportHyperlinks.d.ts +1 -0
- package/lib/ui/supportHyperlinks.js +49 -62
- package/lib/ui/supportsColor.d.ts +1 -0
- package/lib/ui/supportsColor.js +81 -109
- package/lib/ui/table.d.ts +1 -0
- package/lib/ui/table.js +49 -55
- package/lib/upload.d.ts +1 -0
- package/lib/upload.js +40 -43
- package/lib/usageTracking.d.ts +1 -0
- package/lib/usageTracking.js +133 -155
- package/lib/validation.d.ts +1 -0
- package/lib/validation.js +144 -203
- package/package.json +84 -48
- package/CHANGELOG.md +0 -16
- package/commands/__tests__/projects.test.js +0 -105
- package/commands/config/set/allowUsageTracking.js +0 -52
- package/commands/config/set/defaultMode.js +0 -59
- package/commands/config/set/httpTimeout.js +0 -42
- package/commands/project/__tests__/deploy.test.js +0 -443
- package/commands/project/__tests__/installDeps.test.js +0 -168
- package/commands/project/__tests__/logs.test.js +0 -304
- package/hubspot.sample.config.yml +0 -28
- package/jest.config.js +0 -4
- package/lib/__tests__/commonOpts.test.js +0 -83
- package/lib/__tests__/dependencyManagement.test.js +0 -243
- package/lib/__tests__/downloadProjectPrompt.test.js +0 -31
- package/lib/__tests__/projectLogsManager.test.js +0 -212
- package/lib/__tests__/projects.test.js +0 -140
- package/lib/__tests__/serverlessLogs.test.js +0 -162
- package/lib/__tests__/validation.test.js +0 -140
- package/lib/getFunctionArrays.js +0 -18
- package/lib/prompts/__tests__/projectsLogsPrompt.test.js +0 -46
package/lib/validation.js
CHANGED
|
@@ -1,52 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
// @ts-nocheck
|
|
1
4
|
const fs = require('fs');
|
|
2
5
|
const path = require('path');
|
|
3
6
|
const { logger } = require('@hubspot/local-dev-lib/logger');
|
|
4
7
|
const { MODE } = require('@hubspot/local-dev-lib/constants/files');
|
|
5
|
-
const {
|
|
6
|
-
API_KEY_AUTH_METHOD,
|
|
7
|
-
OAUTH_AUTH_METHOD,
|
|
8
|
-
PERSONAL_ACCESS_KEY_AUTH_METHOD,
|
|
9
|
-
} = require('@hubspot/local-dev-lib/constants/auth');
|
|
8
|
+
const { API_KEY_AUTH_METHOD, OAUTH_AUTH_METHOD, PERSONAL_ACCESS_KEY_AUTH_METHOD, } = require('@hubspot/local-dev-lib/constants/auth');
|
|
10
9
|
const { commaSeparatedValues } = require('@hubspot/local-dev-lib/text');
|
|
11
|
-
const {
|
|
12
|
-
loadConfig,
|
|
13
|
-
getConfigPath,
|
|
14
|
-
validateConfig,
|
|
15
|
-
getAccountConfig,
|
|
16
|
-
loadConfigFromEnvironment,
|
|
17
|
-
} = require('@hubspot/local-dev-lib/config');
|
|
10
|
+
const { loadConfig, getConfigPath, validateConfig, getAccountConfig, loadConfigFromEnvironment, } = require('@hubspot/local-dev-lib/config');
|
|
18
11
|
const { getOauthManager } = require('@hubspot/local-dev-lib/oauth');
|
|
19
|
-
const {
|
|
20
|
-
|
|
21
|
-
} = require('@hubspot/local-dev-lib/personalAccessKey');
|
|
22
|
-
const {
|
|
23
|
-
getAbsoluteFilePath,
|
|
24
|
-
getCwd,
|
|
25
|
-
getExt,
|
|
26
|
-
} = require('@hubspot/local-dev-lib/path');
|
|
12
|
+
const { accessTokenForPersonalAccessKey, } = require('@hubspot/local-dev-lib/personalAccessKey');
|
|
13
|
+
const { getAbsoluteFilePath, getCwd, getExt, } = require('@hubspot/local-dev-lib/path');
|
|
27
14
|
const { getAccountId, getMode, setLogLevel } = require('./commonOpts');
|
|
28
15
|
const { logDebugInfo } = require('./debugInfo');
|
|
29
16
|
const { EXIT_CODES } = require('./enums/exitCodes');
|
|
30
17
|
const { checkAndWarnGitInclusion } = require('./ui/git');
|
|
31
18
|
const { logError } = require('./errorHandlers/index');
|
|
32
|
-
|
|
33
19
|
async function loadAndValidateOptions(options, shouldValidateAccount = true) {
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
process.exit(EXIT_CODES.ERROR);
|
|
47
|
-
}
|
|
20
|
+
setLogLevel(options);
|
|
21
|
+
logDebugInfo(options);
|
|
22
|
+
const { config: configPath } = options;
|
|
23
|
+
loadConfig(configPath, options);
|
|
24
|
+
checkAndWarnGitInclusion(getConfigPath());
|
|
25
|
+
let validAccount = true;
|
|
26
|
+
if (shouldValidateAccount) {
|
|
27
|
+
validAccount = await validateAccount(options);
|
|
28
|
+
}
|
|
29
|
+
if (!(validateConfig() && validAccount)) {
|
|
30
|
+
process.exit(EXIT_CODES.ERROR);
|
|
31
|
+
}
|
|
48
32
|
}
|
|
49
|
-
|
|
50
33
|
/**
|
|
51
34
|
* Validate that an account was passed to the command and that the account's configuration is valid
|
|
52
35
|
*
|
|
@@ -55,186 +38,144 @@ async function loadAndValidateOptions(options, shouldValidateAccount = true) {
|
|
|
55
38
|
* @returns {boolean}
|
|
56
39
|
*/
|
|
57
40
|
async function validateAccount(options) {
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
accountId
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
} else if (accountIdOption) {
|
|
74
|
-
logger.error(
|
|
75
|
-
`The account "${accountIdOption}" could not be found in the config`
|
|
76
|
-
);
|
|
77
|
-
} else {
|
|
78
|
-
logger.error(
|
|
79
|
-
'An account needs to be supplied either via "--account" or through setting a "defaultPortal"'
|
|
80
|
-
);
|
|
41
|
+
const accountId = getAccountId(options);
|
|
42
|
+
const { portalId: portalIdOption, portal: portalOption, accountId: _accountIdOption, account: _accountOption, } = options;
|
|
43
|
+
const accountOption = portalOption || _accountOption;
|
|
44
|
+
const accountIdOption = portalIdOption || _accountIdOption;
|
|
45
|
+
if (!accountId) {
|
|
46
|
+
if (accountOption) {
|
|
47
|
+
logger.error(`The account "${accountOption}" could not be found in the config`);
|
|
48
|
+
}
|
|
49
|
+
else if (accountIdOption) {
|
|
50
|
+
logger.error(`The account "${accountIdOption}" could not be found in the config`);
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
logger.error('An account needs to be supplied either via "--account" or through setting a "defaultPortal"');
|
|
54
|
+
}
|
|
55
|
+
return false;
|
|
81
56
|
}
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
);
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
const accountConfig = getAccountConfig(accountId);
|
|
92
|
-
if (!accountConfig) {
|
|
93
|
-
logger.error(`The account ${accountId} has not been configured`);
|
|
94
|
-
return false;
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
const { authType, auth, apiKey, personalAccessKey } = accountConfig;
|
|
98
|
-
|
|
99
|
-
if (typeof authType === 'string' && authType !== authType.toLowerCase()) {
|
|
100
|
-
logger.error(
|
|
101
|
-
`Invalid "authType" value "${authType}" for account "${accountId}" in config file: ${getConfigPath()}. Valid values are ${commaSeparatedValues(
|
|
102
|
-
[
|
|
103
|
-
PERSONAL_ACCESS_KEY_AUTH_METHOD,
|
|
104
|
-
OAUTH_AUTH_METHOD,
|
|
105
|
-
API_KEY_AUTH_METHOD,
|
|
106
|
-
].map(method => method.value)
|
|
107
|
-
)}.`
|
|
108
|
-
);
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
if (authType === 'oauth2') {
|
|
112
|
-
if (typeof auth !== 'object') {
|
|
113
|
-
logger.error(
|
|
114
|
-
`The OAuth2 auth configuration for account ${accountId} is missing`
|
|
115
|
-
);
|
|
116
|
-
return false;
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
const { clientId, clientSecret, tokenInfo } = auth;
|
|
120
|
-
|
|
121
|
-
if (!clientId || !clientSecret || !tokenInfo || !tokenInfo.refreshToken) {
|
|
122
|
-
logger.error(
|
|
123
|
-
`The OAuth2 configuration for account ${accountId} is incorrect`
|
|
124
|
-
);
|
|
125
|
-
logger.error('Run "hs auth --type=oauth2" to reauthenticate');
|
|
126
|
-
return false;
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
const oauth = getOauthManager(accountId, accountConfig);
|
|
130
|
-
try {
|
|
131
|
-
const accessToken = await oauth.accessToken();
|
|
132
|
-
if (!accessToken) {
|
|
133
|
-
logger.error(
|
|
134
|
-
`The OAuth2 access token could not be found for accountId ${accountId}`
|
|
135
|
-
);
|
|
57
|
+
if (accountOption && loadConfigFromEnvironment()) {
|
|
58
|
+
throw new Error('Cannot specify an account when environment variables are supplied. Please unset the environment variables or do not use the "--account" flag.');
|
|
59
|
+
}
|
|
60
|
+
const accountConfig = getAccountConfig(accountId);
|
|
61
|
+
if (!accountConfig) {
|
|
62
|
+
logger.error(`The account ${accountId} has not been configured`);
|
|
136
63
|
return false;
|
|
137
|
-
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
64
|
+
}
|
|
65
|
+
const { authType, auth, apiKey, personalAccessKey } = accountConfig;
|
|
66
|
+
if (typeof authType === 'string' && authType !== authType.toLowerCase()) {
|
|
67
|
+
logger.error(`Invalid "authType" value "${authType}" for account "${accountId}" in config file: ${getConfigPath()}. Valid values are ${commaSeparatedValues([
|
|
68
|
+
PERSONAL_ACCESS_KEY_AUTH_METHOD,
|
|
69
|
+
OAUTH_AUTH_METHOD,
|
|
70
|
+
API_KEY_AUTH_METHOD,
|
|
71
|
+
].map(method => method.value))}.`);
|
|
72
|
+
}
|
|
73
|
+
if (authType === 'oauth2') {
|
|
74
|
+
if (typeof auth !== 'object') {
|
|
75
|
+
logger.error(`The OAuth2 auth configuration for account ${accountId} is missing`);
|
|
76
|
+
return false;
|
|
77
|
+
}
|
|
78
|
+
const { clientId, clientSecret, tokenInfo } = auth;
|
|
79
|
+
if (!clientId || !clientSecret || !tokenInfo || !tokenInfo.refreshToken) {
|
|
80
|
+
logger.error(`The OAuth2 configuration for account ${accountId} is incorrect`);
|
|
81
|
+
logger.error('Run "hs auth --type=oauth2" to reauthenticate');
|
|
82
|
+
return false;
|
|
83
|
+
}
|
|
84
|
+
const oauth = getOauthManager(accountId, accountConfig);
|
|
85
|
+
try {
|
|
86
|
+
const accessToken = await oauth.accessToken();
|
|
87
|
+
if (!accessToken) {
|
|
88
|
+
logger.error(`The OAuth2 access token could not be found for accountId ${accountId}`);
|
|
89
|
+
return false;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
catch (e) {
|
|
93
|
+
logger.error(e.message);
|
|
94
|
+
return false;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
else if (authType === 'personalaccesskey') {
|
|
98
|
+
if (!personalAccessKey) {
|
|
99
|
+
logger.error(`The account "${accountId}" is configured to use a access key for authentication and is missing a "personalAccessKey" in the configuration file`);
|
|
100
|
+
return false;
|
|
101
|
+
}
|
|
102
|
+
try {
|
|
103
|
+
const accessToken = await accessTokenForPersonalAccessKey(accountId);
|
|
104
|
+
if (!accessToken) {
|
|
105
|
+
logger.error(`An OAuth2 access token for account "${accountId} could not be retrieved using the "personalAccessKey" provided`);
|
|
106
|
+
return false;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
catch (e) {
|
|
110
|
+
logError(e);
|
|
111
|
+
return false;
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
else if (!apiKey) {
|
|
115
|
+
logger.error(`The accountId ${accountId} is missing authentication configuration`);
|
|
156
116
|
return false;
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
logError(e);
|
|
160
|
-
return false;
|
|
161
|
-
}
|
|
162
|
-
} else if (!apiKey) {
|
|
163
|
-
logger.error(
|
|
164
|
-
`The accountId ${accountId} is missing authentication configuration`
|
|
165
|
-
);
|
|
166
|
-
return false;
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
return true;
|
|
117
|
+
}
|
|
118
|
+
return true;
|
|
170
119
|
}
|
|
171
|
-
|
|
172
120
|
/**
|
|
173
121
|
* @param {object} command options
|
|
174
122
|
* @returns {boolean}
|
|
175
123
|
*/
|
|
176
124
|
function validateMode(options) {
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
return false;
|
|
125
|
+
const mode = getMode(options);
|
|
126
|
+
if (MODE[mode]) {
|
|
127
|
+
return true;
|
|
128
|
+
}
|
|
129
|
+
const modesMessage = `Available modes are: ${Object.values(MODE).join(', ')}.`;
|
|
130
|
+
if (mode != null) {
|
|
131
|
+
logger.error([`The mode "${mode}" is invalid.`, modesMessage].join(' '));
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
logger.error(['The mode option is missing.', modesMessage].join(' '));
|
|
135
|
+
}
|
|
136
|
+
return false;
|
|
190
137
|
}
|
|
191
|
-
|
|
192
138
|
const fileExists = _path => {
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
return true;
|
|
139
|
+
let isFile;
|
|
140
|
+
try {
|
|
141
|
+
const absoluteSrcPath = path.resolve(getCwd(), _path);
|
|
142
|
+
if (!absoluteSrcPath)
|
|
143
|
+
return false;
|
|
144
|
+
const stats = fs.statSync(absoluteSrcPath);
|
|
145
|
+
isFile = stats.isFile();
|
|
146
|
+
if (!isFile) {
|
|
147
|
+
logger.error(`The path "${_path}" is not a path to a file`);
|
|
148
|
+
return false;
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
catch (e) {
|
|
152
|
+
logger.error(`The path "${_path}" is not a path to a file`);
|
|
153
|
+
return false;
|
|
154
|
+
}
|
|
155
|
+
return true;
|
|
211
156
|
};
|
|
212
|
-
|
|
213
157
|
const checkAndConvertToJson = _path => {
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
return result;
|
|
158
|
+
const filePath = getAbsoluteFilePath(_path);
|
|
159
|
+
if (!fileExists(filePath))
|
|
160
|
+
return false;
|
|
161
|
+
if (getExt(_path) !== 'json') {
|
|
162
|
+
logger.error(`The file "${_path}" must be a valid JSON file`);
|
|
163
|
+
return null;
|
|
164
|
+
}
|
|
165
|
+
let result;
|
|
166
|
+
try {
|
|
167
|
+
result = JSON.parse(fs.readFileSync(filePath, 'utf-8'));
|
|
168
|
+
}
|
|
169
|
+
catch (e) {
|
|
170
|
+
logger.error(`The file "${_path}" contains invalid JSON`);
|
|
171
|
+
result = null;
|
|
172
|
+
}
|
|
173
|
+
return result;
|
|
232
174
|
};
|
|
233
|
-
|
|
234
175
|
module.exports = {
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
176
|
+
validateMode,
|
|
177
|
+
validateAccount,
|
|
178
|
+
checkAndConvertToJson,
|
|
179
|
+
fileExists,
|
|
180
|
+
loadAndValidateOptions,
|
|
240
181
|
};
|
package/package.json
CHANGED
|
@@ -1,50 +1,86 @@
|
|
|
1
1
|
{
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
"
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
"
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
2
|
+
"name": "@hubspot/cli",
|
|
3
|
+
"version": "6.2.2-beta.0",
|
|
4
|
+
"description": "The official CLI for developing on HubSpot",
|
|
5
|
+
"license": "Apache-2.0",
|
|
6
|
+
"repository": "https://github.com/HubSpot/hubspot-cli",
|
|
7
|
+
"dependencies": {
|
|
8
|
+
"@hubspot/local-dev-lib": "2.1.1",
|
|
9
|
+
"@hubspot/serverless-dev-runtime": "7.0.0",
|
|
10
|
+
"@hubspot/theme-preview-dev-server": "0.0.9",
|
|
11
|
+
"@hubspot/ui-extensions-dev-server": "0.8.33",
|
|
12
|
+
"archiver": "^7.0.1",
|
|
13
|
+
"chalk": "^4.1.2",
|
|
14
|
+
"chokidar": "^3.0.1",
|
|
15
|
+
"cli-cursor": "^3.1.0",
|
|
16
|
+
"cli-progress": "^3.11.2",
|
|
17
|
+
"express": "^4.17.1",
|
|
18
|
+
"findup-sync": "^4.0.0",
|
|
19
|
+
"fs-extra": "^8.1.0",
|
|
20
|
+
"inquirer": "8.2.0",
|
|
21
|
+
"jest": "^29.5.0",
|
|
22
|
+
"js-yaml": "^4.1.0",
|
|
23
|
+
"moment": "^2.29.1",
|
|
24
|
+
"open": "^7.0.3",
|
|
25
|
+
"p-queue": "^6.0.2",
|
|
26
|
+
"strip-ansi": "^5.2.0",
|
|
27
|
+
"table": "^6.6.0",
|
|
28
|
+
"tmp": "^0.2.1",
|
|
29
|
+
"update-notifier": "^5.1.0",
|
|
30
|
+
"yargs": "17.7.2"
|
|
31
|
+
},
|
|
32
|
+
"devDependencies": {
|
|
33
|
+
"@types/semver": "^7.5.8",
|
|
34
|
+
"@typescript-eslint/eslint-plugin": "^8.11.0",
|
|
35
|
+
"@typescript-eslint/parser": "^8.11.0",
|
|
36
|
+
"axios": "^1.7.2",
|
|
37
|
+
"eslint": "^8.56.0",
|
|
38
|
+
"eslint-plugin-import": "^2.31.0",
|
|
39
|
+
"husky": "^4.3.8",
|
|
40
|
+
"lint-staged": "^10.5.4",
|
|
41
|
+
"madge": "^8.0.0",
|
|
42
|
+
"mock-stdin": "^1.0.0",
|
|
43
|
+
"prettier": "^1.19.1",
|
|
44
|
+
"semver": "^7.6.3",
|
|
45
|
+
"ts-jest": "^29.2.5",
|
|
46
|
+
"ts-node": "^10.9.2",
|
|
47
|
+
"typescript": "^5.6.2"
|
|
48
|
+
},
|
|
49
|
+
"scripts": {
|
|
50
|
+
"build": "ts-node ./scripts/build.ts",
|
|
51
|
+
"lint": "eslint . && prettier --list-different ./**/*.{js,json}",
|
|
52
|
+
"prettier:write": "prettier --write ./**/*.{js,json}",
|
|
53
|
+
"test": "jest",
|
|
54
|
+
"test-cli": "yarn --cwd 'acceptance-tests' test-ci",
|
|
55
|
+
"test-cli-debug": "yarn --cwd 'acceptance-tests' test-debug",
|
|
56
|
+
"test-cli-qa": "yarn --cwd 'acceptance-tests' test-qa",
|
|
57
|
+
"test-cli-latest": "yarn build-docker && docker container run -it --rm --name=hs-cli-container hs-cli-image yarn --cwd 'acceptance-tests' test-latest",
|
|
58
|
+
"build-docker": "docker image build --tag hs-cli-image . && docker image prune -f",
|
|
59
|
+
"circular-deps": "yarn madge --circular .",
|
|
60
|
+
"release": "yarn ts-node ./scripts/release.ts release",
|
|
61
|
+
"hs": "yarn build && node ./dist/bin/hs",
|
|
62
|
+
"update-ldl": "yarn add --exact @hubspot/local-dev-lib@latest"
|
|
63
|
+
},
|
|
64
|
+
"lint-staged": {
|
|
65
|
+
"**/*.{js,ts,scss,css}": [
|
|
66
|
+
"prettier -l",
|
|
67
|
+
"eslint"
|
|
68
|
+
]
|
|
69
|
+
},
|
|
70
|
+
"husky": {
|
|
71
|
+
"hooks": {
|
|
72
|
+
"pre-commit": "lint-staged"
|
|
73
|
+
}
|
|
74
|
+
},
|
|
75
|
+
"engines": {
|
|
76
|
+
"node": ">=18"
|
|
77
|
+
},
|
|
78
|
+
"bin": {
|
|
79
|
+
"hs": "./bin/hs",
|
|
80
|
+
"hscms": "./bin/hscms"
|
|
81
|
+
},
|
|
82
|
+
"publishConfig": {
|
|
83
|
+
"access": "public",
|
|
84
|
+
"registry": "https://registry.npmjs.org/"
|
|
85
|
+
}
|
|
50
86
|
}
|
package/CHANGELOG.md
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
# Change Log
|
|
2
|
-
|
|
3
|
-
All notable changes to this project will be documented in this file.
|
|
4
|
-
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
|
-
|
|
6
|
-
## [4.1.5](https://github.com/HubSpot/hubspot-cms-tools/compare/v4.1.5-beta.4...v4.1.5) (2023-01-09)
|
|
7
|
-
|
|
8
|
-
**Note:** Version bump only for package @hubspot/cli
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
## [3.0.4](https://github.com/HubSpot/hubspot-cms-tools/compare/v3.0.4-beta.1...v3.0.4) (2021-04-01)
|
|
15
|
-
|
|
16
|
-
**Note:** Version bump only for package @hubspot/cli
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
const { command, describe: projectDescribe, builder } = require('../project');
|
|
2
|
-
|
|
3
|
-
jest.mock('../project/deploy');
|
|
4
|
-
jest.mock('../project/create');
|
|
5
|
-
jest.mock('../project/upload');
|
|
6
|
-
jest.mock('../project/listBuilds');
|
|
7
|
-
jest.mock('../project/logs');
|
|
8
|
-
jest.mock('../project/watch');
|
|
9
|
-
jest.mock('../project/download');
|
|
10
|
-
jest.mock('../project/open');
|
|
11
|
-
jest.mock('../project/dev');
|
|
12
|
-
jest.mock('../project/add');
|
|
13
|
-
jest.mock('../project/migrateApp');
|
|
14
|
-
jest.mock('../project/cloneApp');
|
|
15
|
-
jest.mock('../project/installDeps');
|
|
16
|
-
jest.mock('../../lib/commonOpts');
|
|
17
|
-
|
|
18
|
-
const deploy = require('../project/deploy');
|
|
19
|
-
const create = require('../project/create');
|
|
20
|
-
const upload = require('../project/upload');
|
|
21
|
-
const listBuilds = require('../project/listBuilds');
|
|
22
|
-
const logs = require('../project/logs');
|
|
23
|
-
const watch = require('../project/watch');
|
|
24
|
-
const download = require('../project/download');
|
|
25
|
-
const open = require('../project/open');
|
|
26
|
-
const dev = require('../project/dev');
|
|
27
|
-
const add = require('../project/add');
|
|
28
|
-
const migrateApp = require('../project/migrateApp');
|
|
29
|
-
const cloneApp = require('../project/cloneApp');
|
|
30
|
-
const installDeps = require('../project/installDeps');
|
|
31
|
-
const { addConfigOptions, addAccountOptions } = require('../../lib/commonOpts');
|
|
32
|
-
|
|
33
|
-
describe('commands/projects', () => {
|
|
34
|
-
describe('command', () => {
|
|
35
|
-
it('should have the correct command structure', () => {
|
|
36
|
-
expect(command).toEqual('project');
|
|
37
|
-
});
|
|
38
|
-
});
|
|
39
|
-
|
|
40
|
-
describe('describe', () => {
|
|
41
|
-
it('should contain the beta tag', () => {
|
|
42
|
-
expect(projectDescribe).toContain('[BETA]');
|
|
43
|
-
});
|
|
44
|
-
it('should provide an accurate description of what the command is doing', () => {
|
|
45
|
-
expect(projectDescribe).toContain(
|
|
46
|
-
'Commands for working with projects. For more information, visit our documentation: https://developers.hubspot.com/docs/platform/build-and-deploy-using-hubspot-projects'
|
|
47
|
-
);
|
|
48
|
-
});
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
describe('builder', () => {
|
|
52
|
-
let yargs;
|
|
53
|
-
|
|
54
|
-
const subcommands = [
|
|
55
|
-
['create', create],
|
|
56
|
-
['add', add],
|
|
57
|
-
['watch', watch],
|
|
58
|
-
['dev', dev],
|
|
59
|
-
['upload', upload],
|
|
60
|
-
['deploy', deploy],
|
|
61
|
-
['logs', logs],
|
|
62
|
-
['listBuilds', listBuilds],
|
|
63
|
-
['download', download],
|
|
64
|
-
['open', open],
|
|
65
|
-
['migrateApp', migrateApp],
|
|
66
|
-
['cloneApp', cloneApp],
|
|
67
|
-
['installDeps', installDeps],
|
|
68
|
-
];
|
|
69
|
-
|
|
70
|
-
beforeEach(() => {
|
|
71
|
-
yargs = {
|
|
72
|
-
command: jest.fn().mockImplementation(() => yargs),
|
|
73
|
-
demandCommand: jest.fn().mockImplementation(() => yargs),
|
|
74
|
-
};
|
|
75
|
-
});
|
|
76
|
-
|
|
77
|
-
it('should add the config options', () => {
|
|
78
|
-
builder(yargs);
|
|
79
|
-
expect(addConfigOptions).toHaveBeenCalledTimes(1);
|
|
80
|
-
expect(addConfigOptions).toHaveBeenCalledWith(yargs);
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
it('should add the account options', () => {
|
|
84
|
-
builder(yargs);
|
|
85
|
-
expect(addAccountOptions).toHaveBeenCalledTimes(1);
|
|
86
|
-
expect(addAccountOptions).toHaveBeenCalledWith(yargs);
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
it('should add the correct number of sub commands', () => {
|
|
90
|
-
builder(yargs);
|
|
91
|
-
expect(yargs.command).toHaveBeenCalledTimes(subcommands.length);
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
it.each(subcommands)('should attach the %s subcommand', (name, module) => {
|
|
95
|
-
builder(yargs);
|
|
96
|
-
expect(yargs.command).toHaveBeenCalledWith(module);
|
|
97
|
-
});
|
|
98
|
-
|
|
99
|
-
it('should demand the command takes one positional argument', () => {
|
|
100
|
-
builder(yargs);
|
|
101
|
-
expect(yargs.demandCommand).toHaveBeenCalledTimes(1);
|
|
102
|
-
expect(yargs.demandCommand).toHaveBeenCalledWith(1, '');
|
|
103
|
-
});
|
|
104
|
-
});
|
|
105
|
-
});
|