@hubspot/cli 6.2.0 → 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 (347) 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 -74
  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 +74 -99
  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 -180
  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/lang/en.lyaml +2 -3
  180. package/lib/DevServerManager.d.ts +35 -0
  181. package/lib/DevServerManager.js +97 -124
  182. package/lib/LocalDevManager.d.ts +41 -0
  183. package/lib/LocalDevManager.js +320 -490
  184. package/lib/accountTypes.d.ts +6 -0
  185. package/lib/accountTypes.js +16 -32
  186. package/lib/buildAccount.d.ts +22 -0
  187. package/lib/buildAccount.js +130 -179
  188. package/lib/commonOpts.d.ts +20 -0
  189. package/lib/commonOpts.js +58 -91
  190. package/lib/constants.d.ts +83 -0
  191. package/lib/constants.js +61 -71
  192. package/lib/debugInfo.d.ts +3 -0
  193. package/lib/debugInfo.js +12 -13
  194. package/lib/dependencyManagement.d.ts +7 -0
  195. package/lib/dependencyManagement.js +90 -132
  196. package/lib/developerTestAccounts.d.ts +7 -0
  197. package/lib/developerTestAccounts.js +65 -91
  198. package/lib/enums/exitCodes.d.ts +5 -0
  199. package/lib/enums/exitCodes.js +5 -7
  200. package/lib/environment.d.ts +1 -0
  201. package/lib/environment.js +10 -10
  202. package/lib/errorHandlers/index.d.ts +19 -0
  203. package/lib/errorHandlers/index.js +64 -80
  204. package/lib/errorHandlers/suppressError.d.ts +1 -0
  205. package/lib/errorHandlers/suppressError.js +64 -106
  206. package/lib/filesystem.d.ts +2 -0
  207. package/lib/filesystem.js +16 -24
  208. package/lib/generate-selectors.d.ts +6 -0
  209. package/lib/generate-selectors.js +99 -137
  210. package/lib/getFunctionArrays.d.ts +1 -0
  211. package/lib/getFunctionArrays.js +12 -13
  212. package/lib/hasFeature.d.ts +1 -0
  213. package/lib/hasFeature.js +5 -11
  214. package/lib/hasFlag.d.ts +2 -0
  215. package/lib/hasFlag.js +6 -10
  216. package/lib/hublValidate.d.ts +4 -0
  217. package/lib/hublValidate.js +20 -24
  218. package/lib/interpolation.d.ts +10 -0
  219. package/lib/interpolation.js +48 -92
  220. package/lib/interpolationHelpers.d.ts +6 -0
  221. package/lib/interpolationHelpers.js +19 -19
  222. package/lib/lang.d.ts +3 -0
  223. package/lib/lang.js +50 -78
  224. package/lib/links.d.ts +127 -0
  225. package/lib/links.js +92 -114
  226. package/lib/localDev.d.ts +11 -0
  227. package/lib/localDev.js +283 -433
  228. package/lib/marketplace-validate.d.ts +5 -0
  229. package/lib/marketplace-validate.js +103 -126
  230. package/lib/oauth.d.ts +1 -0
  231. package/lib/oauth.js +62 -78
  232. package/lib/polling.d.ts +1 -0
  233. package/lib/polling.js +24 -26
  234. package/lib/process.d.ts +2 -0
  235. package/lib/process.js +39 -53
  236. package/lib/projectLogsManager.d.ts +19 -0
  237. package/lib/projectLogsManager.js +76 -130
  238. package/lib/projectStructure.d.ts +13 -0
  239. package/lib/projectStructure.js +87 -109
  240. package/lib/projects.d.ts +40 -0
  241. package/lib/projects.js +589 -957
  242. package/lib/projectsWatch.d.ts +1 -0
  243. package/lib/projectsWatch.js +122 -228
  244. package/lib/prompts/accountNamePrompt.d.ts +11 -0
  245. package/lib/prompts/accountNamePrompt.js +58 -65
  246. package/lib/prompts/accountsPrompt.d.ts +3 -0
  247. package/lib/prompts/accountsPrompt.js +31 -37
  248. package/lib/prompts/activeInstallConfirmationPrompt.d.ts +1 -0
  249. package/lib/prompts/activeInstallConfirmationPrompt.js +11 -13
  250. package/lib/prompts/cleanUploadPrompt.d.ts +1 -0
  251. package/lib/prompts/cleanUploadPrompt.js +11 -13
  252. package/lib/prompts/cmsFieldPrompt.d.ts +1 -0
  253. package/lib/prompts/cmsFieldPrompt.js +35 -39
  254. package/lib/prompts/createApiSamplePrompt.d.ts +1 -0
  255. package/lib/prompts/createApiSamplePrompt.js +47 -52
  256. package/lib/prompts/createFunctionPrompt.d.ts +1 -0
  257. package/lib/prompts/createFunctionPrompt.js +55 -56
  258. package/lib/prompts/createModulePrompt.d.ts +1 -0
  259. package/lib/prompts/createModulePrompt.js +45 -50
  260. package/lib/prompts/createProjectPrompt.d.ts +1 -0
  261. package/lib/prompts/createProjectPrompt.js +88 -127
  262. package/lib/prompts/createTemplatePrompt.d.ts +1 -0
  263. package/lib/prompts/createTemplatePrompt.js +16 -19
  264. package/lib/prompts/deployBuildIdPrompt.d.ts +1 -0
  265. package/lib/prompts/deployBuildIdPrompt.js +13 -15
  266. package/lib/prompts/downloadProjectPrompt.d.ts +1 -0
  267. package/lib/prompts/downloadProjectPrompt.js +36 -40
  268. package/lib/prompts/feedbackPrompt.d.ts +2 -0
  269. package/lib/prompts/feedbackPrompt.js +27 -30
  270. package/lib/prompts/folderOverwritePrompt.d.ts +1 -0
  271. package/lib/prompts/folderOverwritePrompt.js +8 -10
  272. package/lib/prompts/installPublicAppPrompt.d.ts +1 -0
  273. package/lib/prompts/installPublicAppPrompt.js +27 -42
  274. package/lib/prompts/personalAccessKeyPrompt.d.ts +69 -0
  275. package/lib/prompts/personalAccessKeyPrompt.js +102 -110
  276. package/lib/prompts/previewPrompt.d.ts +2 -0
  277. package/lib/prompts/previewPrompt.js +44 -47
  278. package/lib/prompts/projectAddPrompt.d.ts +1 -0
  279. package/lib/prompts/projectAddPrompt.js +35 -38
  280. package/lib/prompts/projectDevTargetAccountPrompt.d.ts +4 -0
  281. package/lib/prompts/projectDevTargetAccountPrompt.js +148 -193
  282. package/lib/prompts/projectNamePrompt.d.ts +1 -0
  283. package/lib/prompts/projectNamePrompt.js +23 -25
  284. package/lib/prompts/projectsLogsPrompt.d.ts +5 -0
  285. package/lib/prompts/projectsLogsPrompt.js +19 -27
  286. package/lib/prompts/promptUtils.d.ts +2 -0
  287. package/lib/prompts/promptUtils.js +15 -17
  288. package/lib/prompts/sandboxesPrompt.d.ts +2 -0
  289. package/lib/prompts/sandboxesPrompt.js +48 -59
  290. package/lib/prompts/secretPrompt.d.ts +1 -0
  291. package/lib/prompts/secretPrompt.js +13 -16
  292. package/lib/prompts/selectPublicAppPrompt.d.ts +5 -0
  293. package/lib/prompts/selectPublicAppPrompt.js +55 -81
  294. package/lib/prompts/setAsDefaultAccountPrompt.d.ts +1 -0
  295. package/lib/prompts/setAsDefaultAccountPrompt.js +17 -24
  296. package/lib/prompts/uploadPrompt.d.ts +1 -0
  297. package/lib/prompts/uploadPrompt.js +28 -30
  298. package/lib/regex.d.ts +1 -0
  299. package/lib/regex.js +2 -2
  300. package/lib/sandboxSync.d.ts +8 -0
  301. package/lib/sandboxSync.js +98 -166
  302. package/lib/sandboxes.d.ts +40 -0
  303. package/lib/sandboxes.js +199 -316
  304. package/lib/schema.d.ts +2 -0
  305. package/lib/schema.js +20 -26
  306. package/lib/serverlessLogs.d.ts +8 -0
  307. package/lib/serverlessLogs.js +128 -172
  308. package/lib/ui/SpinniesManager.d.ts +61 -0
  309. package/lib/ui/SpinniesManager.js +196 -254
  310. package/lib/ui/git.d.ts +1 -0
  311. package/lib/ui/git.js +18 -19
  312. package/lib/ui/index.d.ts +36 -0
  313. package/lib/ui/index.js +115 -167
  314. package/lib/ui/serverlessFunctionLogs.d.ts +1 -0
  315. package/lib/ui/serverlessFunctionLogs.js +51 -70
  316. package/lib/ui/spinniesUtils.d.ts +60 -0
  317. package/lib/ui/spinniesUtils.js +109 -133
  318. package/lib/ui/supportHyperlinks.d.ts +3 -0
  319. package/lib/ui/supportHyperlinks.js +46 -61
  320. package/lib/ui/supportsColor.d.ts +13 -0
  321. package/lib/ui/supportsColor.js +78 -108
  322. package/lib/ui/table.d.ts +2 -0
  323. package/lib/ui/table.js +47 -55
  324. package/lib/upload.d.ts +1 -0
  325. package/lib/upload.js +37 -42
  326. package/lib/usageTracking.d.ts +6 -0
  327. package/lib/usageTracking.js +131 -155
  328. package/lib/validation.d.ts +16 -0
  329. package/lib/validation.js +142 -203
  330. package/package.json +78 -48
  331. package/CHANGELOG.md +0 -16
  332. package/LICENSE +0 -12
  333. package/README.md +0 -154
  334. package/commands/__tests__/projects.test.js +0 -105
  335. package/commands/project/__tests__/deploy.test.js +0 -443
  336. package/commands/project/__tests__/installDeps.test.js +0 -168
  337. package/commands/project/__tests__/logs.test.js +0 -304
  338. package/hubspot.sample.config.yml +0 -28
  339. package/jest.config.js +0 -4
  340. package/lib/__tests__/commonOpts.test.js +0 -83
  341. package/lib/__tests__/dependencyManagement.test.js +0 -243
  342. package/lib/__tests__/downloadProjectPrompt.test.js +0 -31
  343. package/lib/__tests__/projectLogsManager.test.js +0 -212
  344. package/lib/__tests__/projects.test.js +0 -140
  345. package/lib/__tests__/serverlessLogs.test.js +0 -162
  346. package/lib/__tests__/validation.test.js +0 -140
  347. 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;