@hubspot/cli 6.2.1 → 6.2.2-experimental.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.
Files changed (346) hide show
  1. package/bin/cli.d.ts +2 -0
  2. package/bin/cli.js +107 -128
  3. package/commands/accounts/clean.d.ts +4 -0
  4. package/commands/accounts/clean.js +80 -116
  5. package/commands/accounts/info.d.ts +4 -0
  6. package/commands/accounts/info.js +30 -43
  7. package/commands/accounts/list.d.ts +4 -0
  8. package/commands/accounts/list.js +63 -92
  9. package/commands/accounts/remove.d.ts +4 -0
  10. package/commands/accounts/remove.js +41 -73
  11. package/commands/accounts/rename.d.ts +4 -0
  12. package/commands/accounts/rename.js +24 -41
  13. package/commands/accounts/use.d.ts +4 -0
  14. package/commands/accounts/use.js +34 -57
  15. package/commands/accounts.d.ts +3 -0
  16. package/commands/accounts.js +14 -18
  17. package/commands/auth.d.ts +4 -0
  18. package/commands/auth.js +131 -200
  19. package/commands/cms/convertFields.d.ts +4 -0
  20. package/commands/cms/convertFields.js +64 -81
  21. package/commands/cms/lighthouseScore.d.ts +4 -0
  22. package/commands/cms/lighthouseScore.js +234 -298
  23. package/commands/cms/reactModules.d.ts +4 -0
  24. package/commands/cms/reactModules.js +44 -53
  25. package/commands/cms.d.ts +3 -0
  26. package/commands/cms.js +9 -13
  27. package/commands/config/set/allowUsageTracking.d.ts +4 -0
  28. package/commands/config/set/allowUsageTracking.js +31 -38
  29. package/commands/config/set/defaultMode.d.ts +4 -0
  30. package/commands/config/set/defaultMode.js +32 -43
  31. package/commands/config/set/httpTimeout.d.ts +4 -0
  32. package/commands/config/set/httpTimeout.js +21 -30
  33. package/commands/config/set.d.ts +4 -0
  34. package/commands/config/set.js +61 -76
  35. package/commands/config.d.ts +3 -0
  36. package/commands/config.js +5 -9
  37. package/commands/create/api-sample.d.ts +13 -0
  38. package/commands/create/api-sample.js +52 -72
  39. package/commands/create/app.d.ts +10 -0
  40. package/commands/create/app.js +6 -7
  41. package/commands/create/function.d.ts +6 -0
  42. package/commands/create/function.js +13 -14
  43. package/commands/create/index.d.ts +109 -0
  44. package/commands/create/index.js +10 -9
  45. package/commands/create/module.d.ts +11 -0
  46. package/commands/create/module.js +19 -19
  47. package/commands/create/react-app.d.ts +9 -0
  48. package/commands/create/react-app.js +5 -6
  49. package/commands/create/template.d.ts +12 -0
  50. package/commands/create/template.js +21 -24
  51. package/commands/create/vue-app.d.ts +9 -0
  52. package/commands/create/vue-app.js +5 -6
  53. package/commands/create/webpack-serverless.d.ts +9 -0
  54. package/commands/create/webpack-serverless.js +5 -6
  55. package/commands/create/website-theme.d.ts +9 -0
  56. package/commands/create/website-theme.js +13 -15
  57. package/commands/create.d.ts +4 -0
  58. package/commands/create.js +62 -80
  59. package/commands/customObject/create.d.ts +4 -0
  60. package/commands/customObject/create.js +31 -47
  61. package/commands/customObject/schema/create.d.ts +4 -0
  62. package/commands/customObject/schema/create.js +40 -67
  63. package/commands/customObject/schema/delete.d.ts +4 -0
  64. package/commands/customObject/schema/delete.js +26 -39
  65. package/commands/customObject/schema/fetch-all.d.ts +4 -0
  66. package/commands/customObject/schema/fetch-all.js +28 -39
  67. package/commands/customObject/schema/fetch.d.ts +4 -0
  68. package/commands/customObject/schema/fetch.js +46 -63
  69. package/commands/customObject/schema/list.d.ts +3 -0
  70. package/commands/customObject/schema/list.js +12 -17
  71. package/commands/customObject/schema/update.d.ts +4 -0
  72. package/commands/customObject/schema/update.js +44 -72
  73. package/commands/customObject/schema.d.ts +3 -0
  74. package/commands/customObject/schema.js +10 -12
  75. package/commands/customObject.d.ts +3 -0
  76. package/commands/customObject.js +12 -22
  77. package/commands/feedback.d.ts +4 -0
  78. package/commands/feedback.js +23 -33
  79. package/commands/fetch.d.ts +4 -0
  80. package/commands/fetch.js +51 -78
  81. package/commands/filemanager/fetch.d.ts +4 -0
  82. package/commands/filemanager/fetch.js +36 -56
  83. package/commands/filemanager/upload.d.ts +4 -0
  84. package/commands/filemanager/upload.js +86 -128
  85. package/commands/filemanager.d.ts +3 -0
  86. package/commands/filemanager.js +10 -18
  87. package/commands/functions/deploy.d.ts +4 -0
  88. package/commands/functions/deploy.js +71 -104
  89. package/commands/functions/list.d.ts +4 -0
  90. package/commands/functions/list.js +29 -47
  91. package/commands/functions/server.d.ts +4 -0
  92. package/commands/functions/server.js +48 -65
  93. package/commands/functions.d.ts +3 -0
  94. package/commands/functions.js +11 -15
  95. package/commands/hubdb/clear.d.ts +4 -0
  96. package/commands/hubdb/clear.js +35 -56
  97. package/commands/hubdb/create.d.ts +4 -0
  98. package/commands/hubdb/create.js +32 -57
  99. package/commands/hubdb/delete.d.ts +4 -0
  100. package/commands/hubdb/delete.js +27 -44
  101. package/commands/hubdb/fetch.d.ts +4 -0
  102. package/commands/hubdb/fetch.js +28 -46
  103. package/commands/hubdb.d.ts +3 -0
  104. package/commands/hubdb.js +10 -14
  105. package/commands/init.d.ts +4 -0
  106. package/commands/init.js +101 -160
  107. package/commands/lint.d.ts +4 -0
  108. package/commands/lint.js +32 -45
  109. package/commands/list.d.ts +4 -0
  110. package/commands/list.js +72 -101
  111. package/commands/logs.d.ts +4 -0
  112. package/commands/logs.js +96 -121
  113. package/commands/module/marketplace-validate.d.ts +4 -0
  114. package/commands/module/marketplace-validate.js +30 -57
  115. package/commands/module.d.ts +3 -0
  116. package/commands/module.js +5 -9
  117. package/commands/mv.d.ts +4 -0
  118. package/commands/mv.js +51 -71
  119. package/commands/open.d.ts +4 -0
  120. package/commands/open.js +46 -62
  121. package/commands/project/add.d.ts +4 -0
  122. package/commands/project/add.js +45 -70
  123. package/commands/project/cloneApp.d.ts +4 -0
  124. package/commands/project/cloneApp.js +117 -178
  125. package/commands/project/create.d.ts +4 -0
  126. package/commands/project/create.js +47 -81
  127. package/commands/project/deploy.d.ts +4 -0
  128. package/commands/project/deploy.js +103 -182
  129. package/commands/project/dev.d.ts +4 -0
  130. package/commands/project/dev.js +123 -227
  131. package/commands/project/download.d.ts +4 -0
  132. package/commands/project/download.js +71 -123
  133. package/commands/project/installDeps.d.ts +6 -0
  134. package/commands/project/installDeps.js +50 -59
  135. package/commands/project/listBuilds.d.ts +4 -0
  136. package/commands/project/listBuilds.js +95 -139
  137. package/commands/project/logs.d.ts +4 -0
  138. package/commands/project/logs.js +84 -128
  139. package/commands/project/migrateApp.d.ts +4 -0
  140. package/commands/project/migrateApp.js +156 -248
  141. package/commands/project/open.d.ts +4 -0
  142. package/commands/project/open.js +42 -68
  143. package/commands/project/upload.d.ts +4 -0
  144. package/commands/project/upload.js +70 -116
  145. package/commands/project/watch.d.ts +4 -0
  146. package/commands/project/watch.js +92 -152
  147. package/commands/project.d.ts +3 -0
  148. package/commands/project.js +19 -23
  149. package/commands/remove.d.ts +4 -0
  150. package/commands/remove.js +26 -43
  151. package/commands/sandbox/create.d.ts +4 -0
  152. package/commands/sandbox/create.js +141 -187
  153. package/commands/sandbox/delete.d.ts +4 -0
  154. package/commands/sandbox/delete.js +164 -221
  155. package/commands/sandbox.d.ts +3 -0
  156. package/commands/sandbox.js +8 -12
  157. package/commands/secrets/addSecret.d.ts +4 -0
  158. package/commands/secrets/addSecret.js +32 -52
  159. package/commands/secrets/deleteSecret.d.ts +4 -0
  160. package/commands/secrets/deleteSecret.js +31 -50
  161. package/commands/secrets/listSecrets.d.ts +4 -0
  162. package/commands/secrets/listSecrets.js +26 -42
  163. package/commands/secrets/updateSecret.d.ts +4 -0
  164. package/commands/secrets/updateSecret.js +33 -53
  165. package/commands/secrets.d.ts +3 -0
  166. package/commands/secrets.js +10 -13
  167. package/commands/theme/generate-selectors.d.ts +4 -0
  168. package/commands/theme/generate-selectors.js +127 -192
  169. package/commands/theme/marketplace-validate.d.ts +4 -0
  170. package/commands/theme/marketplace-validate.js +30 -57
  171. package/commands/theme/preview.d.ts +4 -0
  172. package/commands/theme/preview.js +161 -196
  173. package/commands/theme.d.ts +3 -0
  174. package/commands/theme.js +7 -11
  175. package/commands/upload.d.ts +4 -0
  176. package/commands/upload.js +197 -287
  177. package/commands/watch.d.ts +4 -0
  178. package/commands/watch.js +126 -172
  179. package/lib/DevServerManager.d.ts +35 -0
  180. package/lib/DevServerManager.js +97 -124
  181. package/lib/LocalDevManager.d.ts +41 -0
  182. package/lib/LocalDevManager.js +320 -490
  183. package/lib/accountTypes.d.ts +6 -0
  184. package/lib/accountTypes.js +16 -32
  185. package/lib/buildAccount.d.ts +22 -0
  186. package/lib/buildAccount.js +130 -179
  187. package/lib/commonOpts.d.ts +20 -0
  188. package/lib/commonOpts.js +58 -91
  189. package/lib/constants.d.ts +83 -0
  190. package/lib/constants.js +61 -71
  191. package/lib/debugInfo.d.ts +3 -0
  192. package/lib/debugInfo.js +12 -13
  193. package/lib/dependencyManagement.d.ts +7 -0
  194. package/lib/dependencyManagement.js +90 -132
  195. package/lib/developerTestAccounts.d.ts +7 -0
  196. package/lib/developerTestAccounts.js +65 -91
  197. package/lib/enums/exitCodes.d.ts +5 -0
  198. package/lib/enums/exitCodes.js +5 -7
  199. package/lib/environment.d.ts +1 -0
  200. package/lib/environment.js +10 -10
  201. package/lib/errorHandlers/index.d.ts +19 -0
  202. package/lib/errorHandlers/index.js +64 -80
  203. package/lib/errorHandlers/suppressError.d.ts +1 -0
  204. package/lib/errorHandlers/suppressError.js +64 -106
  205. package/lib/filesystem.d.ts +2 -0
  206. package/lib/filesystem.js +16 -24
  207. package/lib/generate-selectors.d.ts +6 -0
  208. package/lib/generate-selectors.js +99 -137
  209. package/lib/getFunctionArrays.d.ts +1 -0
  210. package/lib/getFunctionArrays.js +12 -13
  211. package/lib/hasFeature.d.ts +1 -0
  212. package/lib/hasFeature.js +5 -11
  213. package/lib/hasFlag.d.ts +2 -0
  214. package/lib/hasFlag.js +6 -10
  215. package/lib/hublValidate.d.ts +4 -0
  216. package/lib/hublValidate.js +20 -24
  217. package/lib/interpolation.d.ts +10 -0
  218. package/lib/interpolation.js +48 -92
  219. package/lib/interpolationHelpers.d.ts +6 -0
  220. package/lib/interpolationHelpers.js +19 -19
  221. package/lib/lang.d.ts +3 -0
  222. package/lib/lang.js +50 -78
  223. package/lib/links.d.ts +127 -0
  224. package/lib/links.js +92 -114
  225. package/lib/localDev.d.ts +11 -0
  226. package/lib/localDev.js +283 -439
  227. package/lib/marketplace-validate.d.ts +5 -0
  228. package/lib/marketplace-validate.js +103 -126
  229. package/lib/oauth.d.ts +1 -0
  230. package/lib/oauth.js +62 -78
  231. package/lib/polling.d.ts +1 -0
  232. package/lib/polling.js +24 -26
  233. package/lib/process.d.ts +2 -0
  234. package/lib/process.js +39 -53
  235. package/lib/projectLogsManager.d.ts +19 -0
  236. package/lib/projectLogsManager.js +76 -130
  237. package/lib/projectStructure.d.ts +13 -0
  238. package/lib/projectStructure.js +87 -109
  239. package/lib/projects.d.ts +40 -0
  240. package/lib/projects.js +589 -960
  241. package/lib/projectsWatch.d.ts +1 -0
  242. package/lib/projectsWatch.js +122 -228
  243. package/lib/prompts/accountNamePrompt.d.ts +11 -0
  244. package/lib/prompts/accountNamePrompt.js +58 -65
  245. package/lib/prompts/accountsPrompt.d.ts +3 -0
  246. package/lib/prompts/accountsPrompt.js +31 -37
  247. package/lib/prompts/activeInstallConfirmationPrompt.d.ts +1 -0
  248. package/lib/prompts/activeInstallConfirmationPrompt.js +11 -13
  249. package/lib/prompts/cleanUploadPrompt.d.ts +1 -0
  250. package/lib/prompts/cleanUploadPrompt.js +11 -13
  251. package/lib/prompts/cmsFieldPrompt.d.ts +1 -0
  252. package/lib/prompts/cmsFieldPrompt.js +35 -39
  253. package/lib/prompts/createApiSamplePrompt.d.ts +1 -0
  254. package/lib/prompts/createApiSamplePrompt.js +47 -52
  255. package/lib/prompts/createFunctionPrompt.d.ts +1 -0
  256. package/lib/prompts/createFunctionPrompt.js +55 -56
  257. package/lib/prompts/createModulePrompt.d.ts +1 -0
  258. package/lib/prompts/createModulePrompt.js +45 -50
  259. package/lib/prompts/createProjectPrompt.d.ts +1 -0
  260. package/lib/prompts/createProjectPrompt.js +88 -127
  261. package/lib/prompts/createTemplatePrompt.d.ts +1 -0
  262. package/lib/prompts/createTemplatePrompt.js +16 -19
  263. package/lib/prompts/deployBuildIdPrompt.d.ts +1 -0
  264. package/lib/prompts/deployBuildIdPrompt.js +13 -15
  265. package/lib/prompts/downloadProjectPrompt.d.ts +1 -0
  266. package/lib/prompts/downloadProjectPrompt.js +36 -40
  267. package/lib/prompts/feedbackPrompt.d.ts +2 -0
  268. package/lib/prompts/feedbackPrompt.js +27 -30
  269. package/lib/prompts/folderOverwritePrompt.d.ts +1 -0
  270. package/lib/prompts/folderOverwritePrompt.js +8 -10
  271. package/lib/prompts/installPublicAppPrompt.d.ts +1 -0
  272. package/lib/prompts/installPublicAppPrompt.js +27 -42
  273. package/lib/prompts/personalAccessKeyPrompt.d.ts +69 -0
  274. package/lib/prompts/personalAccessKeyPrompt.js +102 -110
  275. package/lib/prompts/previewPrompt.d.ts +2 -0
  276. package/lib/prompts/previewPrompt.js +44 -47
  277. package/lib/prompts/projectAddPrompt.d.ts +1 -0
  278. package/lib/prompts/projectAddPrompt.js +35 -38
  279. package/lib/prompts/projectDevTargetAccountPrompt.d.ts +4 -0
  280. package/lib/prompts/projectDevTargetAccountPrompt.js +148 -193
  281. package/lib/prompts/projectNamePrompt.d.ts +1 -0
  282. package/lib/prompts/projectNamePrompt.js +23 -25
  283. package/lib/prompts/projectsLogsPrompt.d.ts +5 -0
  284. package/lib/prompts/projectsLogsPrompt.js +19 -27
  285. package/lib/prompts/promptUtils.d.ts +2 -0
  286. package/lib/prompts/promptUtils.js +15 -17
  287. package/lib/prompts/sandboxesPrompt.d.ts +2 -0
  288. package/lib/prompts/sandboxesPrompt.js +48 -59
  289. package/lib/prompts/secretPrompt.d.ts +1 -0
  290. package/lib/prompts/secretPrompt.js +13 -16
  291. package/lib/prompts/selectPublicAppPrompt.d.ts +5 -0
  292. package/lib/prompts/selectPublicAppPrompt.js +55 -83
  293. package/lib/prompts/setAsDefaultAccountPrompt.d.ts +1 -0
  294. package/lib/prompts/setAsDefaultAccountPrompt.js +17 -24
  295. package/lib/prompts/uploadPrompt.d.ts +1 -0
  296. package/lib/prompts/uploadPrompt.js +28 -30
  297. package/lib/regex.d.ts +1 -0
  298. package/lib/regex.js +2 -2
  299. package/lib/sandboxSync.d.ts +8 -0
  300. package/lib/sandboxSync.js +98 -166
  301. package/lib/sandboxes.d.ts +40 -0
  302. package/lib/sandboxes.js +199 -316
  303. package/lib/schema.d.ts +2 -0
  304. package/lib/schema.js +20 -26
  305. package/lib/serverlessLogs.d.ts +8 -0
  306. package/lib/serverlessLogs.js +128 -172
  307. package/lib/ui/SpinniesManager.d.ts +61 -0
  308. package/lib/ui/SpinniesManager.js +196 -254
  309. package/lib/ui/git.d.ts +1 -0
  310. package/lib/ui/git.js +18 -19
  311. package/lib/ui/index.d.ts +36 -0
  312. package/lib/ui/index.js +115 -167
  313. package/lib/ui/serverlessFunctionLogs.d.ts +1 -0
  314. package/lib/ui/serverlessFunctionLogs.js +51 -70
  315. package/lib/ui/spinniesUtils.d.ts +60 -0
  316. package/lib/ui/spinniesUtils.js +109 -133
  317. package/lib/ui/supportHyperlinks.d.ts +3 -0
  318. package/lib/ui/supportHyperlinks.js +46 -61
  319. package/lib/ui/supportsColor.d.ts +13 -0
  320. package/lib/ui/supportsColor.js +78 -108
  321. package/lib/ui/table.d.ts +2 -0
  322. package/lib/ui/table.js +47 -55
  323. package/lib/upload.d.ts +1 -0
  324. package/lib/upload.js +37 -42
  325. package/lib/usageTracking.d.ts +6 -0
  326. package/lib/usageTracking.js +131 -155
  327. package/lib/validation.d.ts +16 -0
  328. package/lib/validation.js +142 -203
  329. package/package.json +78 -47
  330. package/CHANGELOG.md +0 -16
  331. package/LICENSE +0 -12
  332. package/README.md +0 -154
  333. package/commands/__tests__/projects.test.js +0 -105
  334. package/commands/project/__tests__/deploy.test.js +0 -443
  335. package/commands/project/__tests__/installDeps.test.js +0 -168
  336. package/commands/project/__tests__/logs.test.js +0 -304
  337. package/hubspot.sample.config.yml +0 -28
  338. package/jest.config.js +0 -4
  339. package/lib/__tests__/commonOpts.test.js +0 -83
  340. package/lib/__tests__/dependencyManagement.test.js +0 -243
  341. package/lib/__tests__/downloadProjectPrompt.test.js +0 -31
  342. package/lib/__tests__/projectLogsManager.test.js +0 -212
  343. package/lib/__tests__/projects.test.js +0 -140
  344. package/lib/__tests__/serverlessLogs.test.js +0 -162
  345. package/lib/__tests__/validation.test.js +0 -140
  346. package/lib/prompts/__tests__/projectsLogsPrompt.test.js +0 -46
package/bin/cli.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ #!/usr/bin/env node
2
+ export {};
package/bin/cli.js CHANGED
@@ -1,23 +1,18 @@
1
1
  #!/usr/bin/env node
2
-
2
+ "use strict";
3
3
  const yargs = require('yargs');
4
4
  const updateNotifier = require('update-notifier');
5
5
  const chalk = require('chalk');
6
-
7
6
  const { logger } = require('@hubspot/local-dev-lib/logger');
8
7
  const { addUserAgentHeader } = require('@hubspot/local-dev-lib/http');
9
8
  const { logError } = require('../lib/errorHandlers/index');
10
9
  const { setLogLevel, getCommandName } = require('../lib/commonOpts');
11
- const {
12
- trackHelpUsage,
13
- trackConvertFieldsUsage,
14
- } = require('../lib/usageTracking');
10
+ const { trackHelpUsage, trackConvertFieldsUsage, } = require('../lib/usageTracking');
15
11
  const { getIsInProject } = require('../lib/projects');
16
12
  const pkg = require('../package.json');
17
13
  const { i18n } = require('../lib/lang');
18
14
  const { EXIT_CODES } = require('../lib/enums/exitCodes');
19
15
  const { UI_COLORS, uiCommandReference } = require('../lib/ui');
20
-
21
16
  const removeCommand = require('../commands/remove');
22
17
  const initCommand = require('../commands/init');
23
18
  const logsCommand = require('../commands/logs');
@@ -43,160 +38,144 @@ const accountsCommand = require('../commands/accounts');
43
38
  const sandboxesCommand = require('../commands/sandbox');
44
39
  const cmsCommand = require('../commands/cms');
45
40
  const feedbackCommand = require('../commands/feedback');
46
-
47
41
  const notifier = updateNotifier({
48
- pkg: { ...pkg, name: '@hubspot/cli' },
49
- distTag: 'latest',
50
- shouldNotifyInNpmScript: true,
42
+ pkg: { ...pkg, name: '@hubspot/cli' },
43
+ distTag: 'latest',
44
+ shouldNotifyInNpmScript: true,
51
45
  });
52
-
53
46
  const i18nKey = 'commands.generalErrors';
54
-
55
47
  const CMS_CLI_PACKAGE_NAME = '@hubspot/cms-cli';
56
-
57
48
  notifier.notify({
58
- message:
59
- pkg.name === CMS_CLI_PACKAGE_NAME
60
- ? i18n(`${i18nKey}.updateNotify.cmsUpdateNotification`, {
61
- packageName: CMS_CLI_PACKAGE_NAME,
62
- updateCommand: uiCommandReference('{updateCommand}'),
49
+ message: pkg.name === CMS_CLI_PACKAGE_NAME
50
+ ? i18n(`${i18nKey}.updateNotify.cmsUpdateNotification`, {
51
+ packageName: CMS_CLI_PACKAGE_NAME,
52
+ updateCommand: uiCommandReference('{updateCommand}'),
63
53
  })
64
- : i18n(`${i18nKey}.updateNotify.cliUpdateNotification`, {
65
- updateCommand: uiCommandReference('{updateCommand}'),
54
+ : i18n(`${i18nKey}.updateNotify.cliUpdateNotification`, {
55
+ updateCommand: uiCommandReference('{updateCommand}'),
66
56
  }),
67
- defer: false,
68
- boxenOptions: {
69
- borderColor: UI_COLORS.MARIGOLD_DARK,
70
- margin: 1,
71
- padding: 1,
72
- textAlignment: 'center',
73
- borderStyle: 'round',
74
- title:
75
- pkg.name === CMS_CLI_PACKAGE_NAME
76
- ? null
77
- : chalk.bold(i18n(`${i18nKey}.updateNotify.notifyTitle`)),
78
- },
57
+ defer: false,
58
+ boxenOptions: {
59
+ borderColor: UI_COLORS.MARIGOLD_DARK,
60
+ margin: 1,
61
+ padding: 1,
62
+ textAlignment: 'center',
63
+ borderStyle: 'round',
64
+ title: pkg.name === CMS_CLI_PACKAGE_NAME
65
+ ? null
66
+ : chalk.bold(i18n(`${i18nKey}.updateNotify.notifyTitle`)),
67
+ },
79
68
  });
80
-
81
69
  const getTerminalWidth = () => {
82
- const width = yargs.terminalWidth();
83
-
84
- if (width >= 100) return width * 0.9;
85
-
86
- return width;
70
+ const width = yargs.terminalWidth();
71
+ if (width >= 100)
72
+ return width * 0.9;
73
+ return width;
87
74
  };
88
-
89
75
  const handleFailure = (msg, err, yargs) => {
90
- if (msg) {
91
- logger.error(msg);
92
- } else if (err) {
93
- logError(err);
94
- }
95
-
96
- if (msg === null) {
97
- yargs.showHelp();
98
- process.exit(EXIT_CODES.SUCCESS);
99
- } else {
100
- process.exit(EXIT_CODES.ERROR);
101
- }
76
+ if (msg) {
77
+ logger.error(msg);
78
+ }
79
+ else if (err) {
80
+ logError(err);
81
+ }
82
+ if (msg === null) {
83
+ yargs.showHelp();
84
+ process.exit(EXIT_CODES.SUCCESS);
85
+ }
86
+ else {
87
+ process.exit(EXIT_CODES.ERROR);
88
+ }
102
89
  };
103
-
104
90
  const performChecks = argv => {
105
- // "hs config set default-account" has moved to "hs accounts use"
106
- if (
107
- argv._[0] === 'config' &&
108
- argv._[1] === 'set' &&
109
- argv._[2] === 'default-account'
110
- ) {
111
- logger.error(i18n(`${i18nKey}.setDefaultAccountMoved`));
112
- process.exit(EXIT_CODES.ERROR);
113
- }
114
-
115
- // Require "project" command when running upload/watch inside of a project
116
- if (argv._.length === 1 && ['upload', 'watch'].includes(argv._[0])) {
117
- if (getIsInProject(argv.src)) {
118
- logger.error(
119
- i18n(`${i18nKey}.srcIsProject`, {
120
- src: argv.src || './',
121
- command: argv._.join(' '),
122
- })
123
- );
124
- process.exit(EXIT_CODES.ERROR);
125
- } else {
126
- return true;
91
+ // "hs config set default-account" has moved to "hs accounts use"
92
+ if (argv._[0] === 'config' &&
93
+ argv._[1] === 'set' &&
94
+ argv._[2] === 'default-account') {
95
+ logger.error(i18n(`${i18nKey}.setDefaultAccountMoved`));
96
+ process.exit(EXIT_CODES.ERROR);
97
+ }
98
+ // Require "project" command when running upload/watch inside of a project
99
+ if (argv._.length === 1 && ['upload', 'watch'].includes(argv._[0])) {
100
+ if (getIsInProject(argv.src)) {
101
+ logger.error(i18n(`${i18nKey}.srcIsProject`, {
102
+ src: argv.src || './',
103
+ command: argv._.join(' '),
104
+ }));
105
+ process.exit(EXIT_CODES.ERROR);
106
+ }
107
+ else {
108
+ return true;
109
+ }
110
+ }
111
+ else {
112
+ return true;
127
113
  }
128
- } else {
129
- return true;
130
- }
131
114
  };
132
-
133
115
  const setRequestHeaders = () => {
134
- addUserAgentHeader('HubSpot CLI', pkg.version);
116
+ addUserAgentHeader('HubSpot CLI', pkg.version);
135
117
  };
136
-
137
118
  const argv = yargs
138
- .usage('The command line interface to interact with HubSpot.')
139
- .middleware([setLogLevel, setRequestHeaders])
140
- .exitProcess(false)
141
- .fail(handleFailure)
142
- .option('debug', {
119
+ .usage('The command line interface to interact with HubSpot.')
120
+ .middleware([setLogLevel, setRequestHeaders])
121
+ .exitProcess(false)
122
+ .fail(handleFailure)
123
+ .option('debug', {
143
124
  alias: 'd',
144
125
  default: false,
145
126
  describe: 'Set log level to debug',
146
127
  type: 'boolean',
147
- })
148
- .option('noHyperlinks', {
128
+ })
129
+ .option('noHyperlinks', {
149
130
  default: false,
150
131
  describe: 'prevent hyperlinks from displaying in the ui',
151
132
  hidden: true,
152
133
  type: 'boolean',
153
- })
154
- .option('noColor', {
134
+ })
135
+ .option('noColor', {
155
136
  default: false,
156
137
  describe: 'prevent color from displaying in the ui',
157
138
  hidden: true,
158
139
  type: 'boolean',
159
- })
160
- .check(performChecks)
161
- .command(authCommand)
162
- .command(initCommand)
163
- .command(logsCommand)
164
- .command(cmsCommand)
165
- .command(lintCommand)
166
- .command(hubdbCommand)
167
- .command(watchCommand)
168
- .command(removeCommand)
169
- .command(uploadCommand)
170
- .command(createCommand)
171
- .command(fetchCommand)
172
- .command(filemanagerCommand)
173
- .command(secretsCommand)
174
- .command(customObjectCommand)
175
- .command(functionsCommand)
176
- .command({
140
+ })
141
+ .check(performChecks)
142
+ .command(authCommand)
143
+ .command(initCommand)
144
+ .command(logsCommand)
145
+ .command(cmsCommand)
146
+ .command(lintCommand)
147
+ .command(hubdbCommand)
148
+ .command(watchCommand)
149
+ .command(removeCommand)
150
+ .command(uploadCommand)
151
+ .command(createCommand)
152
+ .command(fetchCommand)
153
+ .command(filemanagerCommand)
154
+ .command(secretsCommand)
155
+ .command(customObjectCommand)
156
+ .command(functionsCommand)
157
+ .command({
177
158
  ...listCommand,
178
159
  aliases: 'ls',
179
- })
180
- .command(openCommand)
181
- .command(mvCommand)
182
- .command(projectCommands)
183
- .command(themeCommand)
184
- .command(moduleCommand)
185
- .command(configCommand)
186
- .command(accountsCommand)
187
- .command(sandboxesCommand)
188
- .command(feedbackCommand)
189
- .help()
190
- .recommendCommands()
191
- .demandCommand(1, '')
192
- .completion()
193
- .wrap(getTerminalWidth())
194
- .strict().argv;
195
-
160
+ })
161
+ .command(openCommand)
162
+ .command(mvCommand)
163
+ .command(projectCommands)
164
+ .command(themeCommand)
165
+ .command(moduleCommand)
166
+ .command(configCommand)
167
+ .command(accountsCommand)
168
+ .command(sandboxesCommand)
169
+ .command(feedbackCommand)
170
+ .help()
171
+ .recommendCommands()
172
+ .demandCommand(1, '')
173
+ .completion()
174
+ .wrap(getTerminalWidth())
175
+ .strict().argv;
196
176
  if (argv.help) {
197
- trackHelpUsage(getCommandName(argv));
177
+ trackHelpUsage(getCommandName(argv));
198
178
  }
199
-
200
179
  if (argv.convertFields) {
201
- trackConvertFieldsUsage(getCommandName(argv));
180
+ trackConvertFieldsUsage(getCommandName(argv));
202
181
  }
@@ -0,0 +1,4 @@
1
+ export const command: "clean";
2
+ export const describe: any;
3
+ export function handler(options: any): Promise<never>;
4
+ export function builder(yargs: any): any;
@@ -1,136 +1,100 @@
1
+ "use strict";
1
2
  const { logger } = require('@hubspot/local-dev-lib/logger');
2
- const {
3
- accessTokenForPersonalAccessKey,
4
- } = require('@hubspot/local-dev-lib/personalAccessKey');
5
-
3
+ const { accessTokenForPersonalAccessKey, } = require('@hubspot/local-dev-lib/personalAccessKey');
6
4
  const { trackCommandUsage } = require('../../lib/usageTracking');
7
5
  const { i18n } = require('../../lib/lang');
8
6
  const { loadAndValidateOptions } = require('../../lib/validation');
9
7
  const { EXIT_CODES } = require('../../lib/enums/exitCodes');
10
- const {
11
- addConfigOptions,
12
- addAccountOptions,
13
- addUseEnvironmentOptions,
14
- addTestingOptions,
15
- } = require('../../lib/commonOpts');
8
+ const { addConfigOptions, addAccountOptions, addUseEnvironmentOptions, addTestingOptions, } = require('../../lib/commonOpts');
16
9
  const { promptUser } = require('../../lib/prompts/promptUtils');
17
10
  const { getTableContents } = require('../../lib/ui/table');
18
11
  const SpinniesManager = require('../../lib/ui/SpinniesManager');
19
12
  const { getConfig, deleteAccount } = require('@hubspot/local-dev-lib/config');
20
13
  const { uiAccountDescription } = require('../../lib/ui');
21
14
  const { isSpecifiedError } = require('@hubspot/local-dev-lib/errors/index');
22
-
23
15
  const i18nKey = 'commands.accounts.subcommands.clean';
24
-
25
16
  exports.command = 'clean';
26
17
  exports.describe = i18n(`${i18nKey}.describe`);
27
-
28
- exports.handler = async options => {
29
- const { qa } = options;
30
- await loadAndValidateOptions(options, false);
31
-
32
- const config = getConfig();
33
-
34
- trackCommandUsage('accounts-clean', null);
35
-
36
- const filteredTestAccounts = config.portals.filter(p =>
37
- qa ? p.env === 'qa' : p.env !== 'qa'
38
- );
39
-
40
- if (filteredTestAccounts && filteredTestAccounts.length === 0) {
41
- logger.log(i18n(`${i18nKey}.noResults`));
42
- process.exit(EXIT_CODES.SUCCESS);
43
- }
44
-
45
- const accountsToRemove = [];
46
- SpinniesManager.init({
47
- succeedColor: 'white',
48
- });
49
- SpinniesManager.add('accountsClean', {
50
- text: i18n(`${i18nKey}.loading.add`),
51
- });
52
-
53
- for (const account of filteredTestAccounts) {
54
- try {
55
- await accessTokenForPersonalAccessKey(account.portalId, true);
56
- } catch (error) {
57
- if (
58
- isSpecifiedError(error, {
59
- statusCode: 401,
60
- category: 'INVALID_AUTHENTICATION',
61
- subCategory: 'LocalDevAuthErrorType.PORTAL_NOT_ACTIVE',
62
- }) ||
63
- isSpecifiedError(error, {
64
- statusCode: 404,
65
- category: 'INVALID_AUTHENTICATION',
66
- subCategory: 'LocalDevAuthErrorType.INVALID_PORTAL_ID',
67
- })
68
- ) {
69
- accountsToRemove.push(account);
70
- }
18
+ exports.handler = async (options) => {
19
+ const { qa } = options;
20
+ await loadAndValidateOptions(options, false);
21
+ const config = getConfig();
22
+ trackCommandUsage('accounts-clean', null);
23
+ const filteredTestAccounts = config.portals.filter(p => qa ? p.env === 'qa' : p.env !== 'qa');
24
+ if (filteredTestAccounts && filteredTestAccounts.length === 0) {
25
+ logger.log(i18n(`${i18nKey}.noResults`));
26
+ process.exit(EXIT_CODES.SUCCESS);
71
27
  }
72
- }
73
-
74
- if (accountsToRemove.length > 0) {
75
- const oneAccountFound = accountsToRemove.length === 1;
76
- SpinniesManager.succeed('accountsClean', {
77
- text: i18n(
78
- oneAccountFound
79
- ? `${i18nKey}.inactiveAccountsFound.one`
80
- : `${i18nKey}.inactiveAccountsFound.other`,
81
- {
82
- count: accountsToRemove.length,
83
- }
84
- ),
28
+ const accountsToRemove = [];
29
+ SpinniesManager.init({
30
+ succeedColor: 'white',
85
31
  });
86
- logger.log(
87
- getTableContents(
88
- accountsToRemove.map(p => [uiAccountDescription(p.portalId)]),
89
- { border: { bodyLeft: ' ' } }
90
- )
91
- );
92
- const { accountsCleanPrompt } = await promptUser([
93
- {
94
- name: 'accountsCleanPrompt',
95
- type: 'confirm',
96
- message: i18n(
97
- oneAccountFound
98
- ? `${i18nKey}.confirm.one`
99
- : `${i18nKey}.confirm.other`,
100
- {
101
- count: accountsToRemove.length,
102
- }
103
- ),
104
- },
105
- ]);
106
- if (accountsCleanPrompt) {
107
- logger.log('');
108
- for (const accountToRemove of accountsToRemove) {
109
- await deleteAccount(accountToRemove.name);
110
- logger.log(
111
- i18n(`${i18nKey}.removeSuccess`, {
112
- accountName: accountToRemove.name,
113
- })
114
- );
115
- }
116
- }
117
- } else {
118
- SpinniesManager.succeed('accountsClean', {
119
- text: i18n(`${i18nKey}.noResults`),
32
+ SpinniesManager.add('accountsClean', {
33
+ text: i18n(`${i18nKey}.loading.add`),
120
34
  });
121
- }
122
-
123
- logger.log('');
124
- process.exit(EXIT_CODES.SUCCESS);
35
+ for (const account of filteredTestAccounts) {
36
+ try {
37
+ await accessTokenForPersonalAccessKey(account.portalId, true);
38
+ }
39
+ catch (error) {
40
+ if (isSpecifiedError(error, {
41
+ statusCode: 401,
42
+ category: 'INVALID_AUTHENTICATION',
43
+ subCategory: 'LocalDevAuthErrorType.PORTAL_NOT_ACTIVE',
44
+ }) ||
45
+ isSpecifiedError(error, {
46
+ statusCode: 404,
47
+ category: 'INVALID_AUTHENTICATION',
48
+ subCategory: 'LocalDevAuthErrorType.INVALID_PORTAL_ID',
49
+ })) {
50
+ accountsToRemove.push(account);
51
+ }
52
+ }
53
+ }
54
+ if (accountsToRemove.length > 0) {
55
+ const oneAccountFound = accountsToRemove.length === 1;
56
+ SpinniesManager.succeed('accountsClean', {
57
+ text: i18n(oneAccountFound
58
+ ? `${i18nKey}.inactiveAccountsFound.one`
59
+ : `${i18nKey}.inactiveAccountsFound.other`, {
60
+ count: accountsToRemove.length,
61
+ }),
62
+ });
63
+ logger.log(getTableContents(accountsToRemove.map(p => [uiAccountDescription(p.portalId)]), { border: { bodyLeft: ' ' } }));
64
+ const { accountsCleanPrompt } = await promptUser([
65
+ {
66
+ name: 'accountsCleanPrompt',
67
+ type: 'confirm',
68
+ message: i18n(oneAccountFound
69
+ ? `${i18nKey}.confirm.one`
70
+ : `${i18nKey}.confirm.other`, {
71
+ count: accountsToRemove.length,
72
+ }),
73
+ },
74
+ ]);
75
+ if (accountsCleanPrompt) {
76
+ logger.log('');
77
+ for (const accountToRemove of accountsToRemove) {
78
+ await deleteAccount(accountToRemove.name);
79
+ logger.log(i18n(`${i18nKey}.removeSuccess`, {
80
+ accountName: accountToRemove.name,
81
+ }));
82
+ }
83
+ }
84
+ }
85
+ else {
86
+ SpinniesManager.succeed('accountsClean', {
87
+ text: i18n(`${i18nKey}.noResults`),
88
+ });
89
+ }
90
+ logger.log('');
91
+ process.exit(EXIT_CODES.SUCCESS);
125
92
  };
126
-
127
93
  exports.builder = yargs => {
128
- addConfigOptions(yargs);
129
- addAccountOptions(yargs);
130
- addUseEnvironmentOptions(yargs);
131
- addTestingOptions(yargs);
132
-
133
- yargs.example([['$0 accounts clean']]);
134
-
135
- return yargs;
94
+ addConfigOptions(yargs);
95
+ addAccountOptions(yargs);
96
+ addUseEnvironmentOptions(yargs);
97
+ addTestingOptions(yargs);
98
+ yargs.example([['$0 accounts clean']]);
99
+ return yargs;
136
100
  };
@@ -0,0 +1,4 @@
1
+ export const describe: any;
2
+ export const command: "info [--account]";
3
+ export function handler(options: any): Promise<void>;
4
+ export function builder(yargs: any): any;
@@ -1,55 +1,42 @@
1
+ "use strict";
1
2
  const { logger } = require('@hubspot/local-dev-lib/logger');
2
3
  const { getAccountConfig } = require('@hubspot/local-dev-lib/config');
3
4
  const { getAccessToken } = require('@hubspot/local-dev-lib/personalAccessKey');
4
- const {
5
- getAccountId,
6
- addAccountOptions,
7
- addConfigOptions,
8
- } = require('../../lib/commonOpts');
5
+ const { getAccountId, addAccountOptions, addConfigOptions, } = require('../../lib/commonOpts');
9
6
  const { loadAndValidateOptions } = require('../../lib/validation');
10
7
  const { i18n } = require('../../lib/lang');
11
8
  const { getTableContents } = require('../../lib/ui/table');
12
-
13
9
  const i18nKey = 'commands.accounts.subcommands.info';
14
10
  exports.describe = i18n(`${i18nKey}.describe`);
15
-
16
11
  exports.command = 'info [--account]';
17
-
18
- exports.handler = async options => {
19
- await loadAndValidateOptions(options);
20
-
21
- let accountId = getAccountId(options);
22
- const config = getAccountConfig(accountId);
23
-
24
- // check if the provided account is using a personal access key, if not, show an error
25
- if (config.authType === 'personalaccesskey') {
26
- const { name, personalAccessKey, env } = config;
27
-
28
- const response = await getAccessToken(personalAccessKey, env, accountId);
29
-
30
- const scopeGroups = response.scopeGroups.map(s => [s]);
31
-
32
- logger.log(i18n(`${i18nKey}.name`, { name }));
33
- logger.log(i18n(`${i18nKey}.accountId`, { accountId }));
34
- logger.log(i18n(`${i18nKey}.scopeGroups`));
35
- logger.log(getTableContents(scopeGroups, { border: { bodyLeft: ' ' } }));
36
- } else {
37
- logger.log(i18n(`${i18nKey}.errors.notUsingPersonalAccessKey`));
38
- }
12
+ exports.handler = async (options) => {
13
+ await loadAndValidateOptions(options);
14
+ let accountId = getAccountId(options);
15
+ const config = getAccountConfig(accountId);
16
+ // check if the provided account is using a personal access key, if not, show an error
17
+ if (config.authType === 'personalaccesskey') {
18
+ const { name, personalAccessKey, env } = config;
19
+ const response = await getAccessToken(personalAccessKey, env, accountId);
20
+ const scopeGroups = response.scopeGroups.map(s => [s]);
21
+ logger.log(i18n(`${i18nKey}.name`, { name }));
22
+ logger.log(i18n(`${i18nKey}.accountId`, { accountId }));
23
+ logger.log(i18n(`${i18nKey}.scopeGroups`));
24
+ logger.log(getTableContents(scopeGroups, { border: { bodyLeft: ' ' } }));
25
+ }
26
+ else {
27
+ logger.log(i18n(`${i18nKey}.errors.notUsingPersonalAccessKey`));
28
+ }
39
29
  };
40
-
41
30
  exports.builder = yargs => {
42
- addConfigOptions(yargs);
43
- addAccountOptions(yargs);
44
-
45
- yargs.example([
46
- ['$0 accounts info', i18n(`${i18nKey}.examples.default`)],
47
- [
48
- '$0 accounts info --account=MyAccount',
49
- i18n(`${i18nKey}.examples.nameBased`),
50
- ],
51
- ['$0 accounts info --account=1234567', i18n(`${i18nKey}.examples.idBased`)],
52
- ]);
53
-
54
- return yargs;
31
+ addConfigOptions(yargs);
32
+ addAccountOptions(yargs);
33
+ yargs.example([
34
+ ['$0 accounts info', i18n(`${i18nKey}.examples.default`)],
35
+ [
36
+ '$0 accounts info --account=MyAccount',
37
+ i18n(`${i18nKey}.examples.nameBased`),
38
+ ],
39
+ ['$0 accounts info --account=1234567', i18n(`${i18nKey}.examples.idBased`)],
40
+ ]);
41
+ return yargs;
55
42
  };
@@ -0,0 +1,4 @@
1
+ export const command: "list";
2
+ export const describe: any;
3
+ export function handler(options: any): Promise<void>;
4
+ export function builder(yargs: any): any;