@hubspot/cli 7.8.0-experimental.0 → 7.8.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 (357) hide show
  1. package/bin/cli.js +31 -27
  2. package/commands/__tests__/auth.test.js +5 -0
  3. package/commands/__tests__/doctor.test.js +16 -16
  4. package/commands/__tests__/getStarted.test.js +2 -2
  5. package/commands/__tests__/mcp.test.js +1 -1
  6. package/commands/__tests__/project.test.js +2 -3
  7. package/commands/account/auth.js +1 -0
  8. package/commands/account/clean.js +18 -27
  9. package/commands/account/createOverride.js +13 -31
  10. package/commands/account/info.js +20 -31
  11. package/commands/account/list.js +16 -22
  12. package/commands/account/remove.js +12 -20
  13. package/commands/account/removeOverride.js +11 -21
  14. package/commands/account/rename.js +6 -9
  15. package/commands/account/use.js +12 -26
  16. package/commands/account.js +2 -2
  17. package/commands/app/__tests__/migrate.test.js +5 -6
  18. package/commands/app/migrate.js +13 -19
  19. package/commands/app/secret/add.js +2 -1
  20. package/commands/app/secret/delete.js +2 -1
  21. package/commands/app/secret/list.js +2 -1
  22. package/commands/app/secret/update.js +2 -1
  23. package/commands/app/secret.js +2 -1
  24. package/commands/app.js +2 -2
  25. package/commands/auth.d.ts +1 -0
  26. package/commands/auth.js +17 -7
  27. package/commands/cms/convertFields.js +7 -9
  28. package/commands/cms/getReactModule.js +9 -14
  29. package/commands/cms/lighthouseScore.js +33 -36
  30. package/commands/cms.js +2 -2
  31. package/commands/completion.js +3 -3
  32. package/commands/config/set.d.ts +1 -1
  33. package/commands/config/set.js +64 -37
  34. package/commands/config.js +2 -2
  35. package/commands/create.js +2 -2
  36. package/commands/customObject/create.js +10 -12
  37. package/commands/customObject/schema/create.js +9 -11
  38. package/commands/customObject/schema/delete.js +16 -16
  39. package/commands/customObject/schema/fetch-all.js +12 -11
  40. package/commands/customObject/schema/fetch.js +15 -15
  41. package/commands/customObject/schema/list.js +4 -4
  42. package/commands/customObject/schema/update.js +13 -13
  43. package/commands/customObject/schema.js +2 -2
  44. package/commands/customObject.js +6 -7
  45. package/commands/doctor.js +8 -11
  46. package/commands/feedback.js +8 -13
  47. package/commands/fetch.js +8 -8
  48. package/commands/filemanager/fetch.js +7 -7
  49. package/commands/filemanager/upload.js +15 -34
  50. package/commands/filemanager.js +2 -2
  51. package/commands/function/deploy.js +11 -29
  52. package/commands/function/list.js +8 -8
  53. package/commands/function/server.js +9 -11
  54. package/commands/function.d.ts +1 -1
  55. package/commands/function.js +2 -2
  56. package/commands/getStarted.d.ts +1 -3
  57. package/commands/getStarted.js +68 -20
  58. package/commands/hubdb/clear.js +7 -15
  59. package/commands/hubdb/create.js +9 -15
  60. package/commands/hubdb/delete.js +8 -15
  61. package/commands/hubdb/fetch.js +6 -9
  62. package/commands/hubdb.d.ts +1 -1
  63. package/commands/hubdb.js +2 -2
  64. package/commands/init.js +2 -3
  65. package/commands/lint.js +16 -16
  66. package/commands/list.js +8 -14
  67. package/commands/logs.js +14 -20
  68. package/commands/mcp/__tests__/setup.test.js +2 -2
  69. package/commands/mcp/setup.js +11 -2
  70. package/commands/mcp.js +3 -3
  71. package/commands/mv.js +6 -17
  72. package/commands/open.js +5 -5
  73. package/commands/project/__tests__/add.test.js +15 -13
  74. package/commands/project/__tests__/create.test.js +6 -6
  75. package/commands/project/__tests__/deploy.test.js +3 -7
  76. package/commands/project/__tests__/devUnifiedFlow.test.js +2 -4
  77. package/commands/project/__tests__/installDeps.test.js +8 -8
  78. package/commands/project/__tests__/list.test.js +31 -0
  79. package/commands/project/__tests__/logs.test.js +1 -4
  80. package/commands/project/__tests__/migrate.test.js +7 -7
  81. package/commands/project/__tests__/migrateApp.test.js +3 -7
  82. package/commands/project/__tests__/profile.test.js +1 -1
  83. package/commands/project/__tests__/validate.test.js +98 -0
  84. package/commands/project/add.d.ts +2 -2
  85. package/commands/project/add.js +7 -10
  86. package/commands/project/cloneApp.js +14 -19
  87. package/commands/project/create.js +4 -11
  88. package/commands/project/deploy.js +5 -5
  89. package/commands/project/dev/deprecatedFlow.js +9 -18
  90. package/commands/project/dev/index.js +21 -18
  91. package/commands/project/dev/unifiedFlow.js +15 -8
  92. package/commands/project/download.js +15 -16
  93. package/commands/project/installDeps.d.ts +2 -2
  94. package/commands/project/installDeps.js +9 -9
  95. package/commands/project/list.d.ts +4 -0
  96. package/commands/project/list.js +62 -0
  97. package/commands/project/listBuilds.js +12 -21
  98. package/commands/project/logs.js +21 -24
  99. package/commands/project/migrate.js +33 -12
  100. package/commands/project/migrateApp.js +10 -17
  101. package/commands/project/open.js +6 -14
  102. package/commands/project/profile/add.js +3 -3
  103. package/commands/project/profile/delete.js +1 -2
  104. package/commands/project/profile.js +2 -3
  105. package/commands/project/upload.js +16 -25
  106. package/commands/project/validate.js +7 -7
  107. package/commands/project/watch.js +13 -22
  108. package/commands/project.js +4 -3
  109. package/commands/sandbox/__tests__/create.test.js +5 -5
  110. package/commands/sandbox/create.js +22 -32
  111. package/commands/sandbox/delete.js +39 -64
  112. package/commands/sandbox.js +2 -2
  113. package/commands/secret/addSecret.js +7 -17
  114. package/commands/secret/deleteSecret.js +10 -20
  115. package/commands/secret/listSecret.js +8 -10
  116. package/commands/secret/updateSecret.js +9 -17
  117. package/commands/secret.js +2 -2
  118. package/commands/testAccount/__tests__/delete.test.js +2 -4
  119. package/commands/testAccount/create.js +2 -2
  120. package/commands/testAccount/delete.d.ts +4 -3
  121. package/commands/testAccount/delete.js +155 -14
  122. package/commands/testAccount/importData.d.ts +1 -1
  123. package/commands/testAccount/importData.js +1 -1
  124. package/commands/testAccount.js +1 -1
  125. package/commands/theme/preview.js +1 -4
  126. package/lang/en.d.ts +365 -111
  127. package/lang/en.js +409 -158
  128. package/lang/en.lyaml +4 -4
  129. package/lib/__tests__/buildAccount.test.js +4 -3
  130. package/lib/__tests__/commonOpts.test.js +1 -1
  131. package/lib/__tests__/dependencyManagement.test.js +1 -1
  132. package/lib/__tests__/developerTestAccounts.test.js +3 -3
  133. package/lib/__tests__/hasFeature.test.js +145 -7
  134. package/lib/__tests__/npm.test.js +1 -1
  135. package/lib/__tests__/oauth.test.js +4 -4
  136. package/lib/__tests__/process.test.js +10 -5
  137. package/lib/__tests__/sandboxSync.test.js +8 -8
  138. package/lib/__tests__/sandboxes.test.js +8 -8
  139. package/lib/__tests__/serverlessLogs.test.js +1 -1
  140. package/lib/__tests__/usageTracking.test.js +5 -5
  141. package/lib/__tests__/validation.test.js +2 -1
  142. package/lib/__tests__/yargsUtils.test.js +83 -9
  143. package/lib/app/__tests__/migrate.test.js +19 -56
  144. package/lib/app/__tests__/migrate_legacy.test.js +1 -1
  145. package/lib/app/migrate.d.ts +2 -8
  146. package/lib/app/migrate.js +6 -81
  147. package/lib/app/migrate_legacy.js +20 -24
  148. package/lib/buildAccount.d.ts +2 -2
  149. package/lib/buildAccount.js +32 -64
  150. package/lib/commonOpts.d.ts +1 -1
  151. package/lib/commonOpts.js +25 -22
  152. package/lib/configMigrate.js +88 -9
  153. package/lib/configOptions.js +7 -0
  154. package/lib/constants.d.ts +22 -1
  155. package/lib/constants.js +26 -1
  156. package/lib/dependencyManagement.d.ts +0 -5
  157. package/lib/dependencyManagement.js +9 -36
  158. package/lib/developerTestAccounts.js +9 -23
  159. package/lib/doctor/Diagnosis.js +11 -23
  160. package/lib/doctor/DiagnosticInfoBuilder.js +12 -11
  161. package/lib/doctor/Doctor.js +42 -90
  162. package/lib/doctor/__tests__/Doctor.test.js +4 -4
  163. package/lib/errorHandlers/index.js +12 -20
  164. package/lib/errorHandlers/suppressError.js +11 -18
  165. package/lib/hasFeature.js +6 -0
  166. package/lib/lang.js +6 -5
  167. package/lib/links.d.ts +1 -0
  168. package/lib/links.js +14 -7
  169. package/lib/mcp/setup.js +1 -1
  170. package/lib/middleware/__test__/commandTargetingUtils.test.js +99 -0
  171. package/lib/middleware/__test__/configMiddleware.test.js +11 -11
  172. package/lib/middleware/__test__/yargsChecksMiddleware.test.js +6 -8
  173. package/lib/middleware/commandTargetingUtils.d.ts +8 -0
  174. package/lib/middleware/commandTargetingUtils.js +74 -0
  175. package/lib/middleware/configMiddleware.d.ts +1 -1
  176. package/lib/middleware/configMiddleware.js +21 -81
  177. package/lib/middleware/fireAlarmMiddleware.js +15 -5
  178. package/lib/middleware/gitMiddleware.js +5 -1
  179. package/lib/middleware/notificationsMiddleware.js +5 -11
  180. package/lib/middleware/yargsChecksMiddleware.js +6 -9
  181. package/lib/npm.js +2 -2
  182. package/lib/oauth.js +5 -5
  183. package/lib/process.js +5 -4
  184. package/lib/projects/__tests__/AppDevModeInterface.test.js +87 -90
  185. package/lib/projects/__tests__/LocalDevProcess.test.js +231 -19
  186. package/lib/projects/__tests__/LocalDevWebsocketServer.test.js +89 -63
  187. package/lib/projects/__tests__/deploy.test.js +73 -8
  188. package/lib/projects/__tests__/localDevProjectHelpers.test.js +6 -2
  189. package/lib/projects/__tests__/platformVersion.test.js +8 -8
  190. package/lib/projects/__tests__/projects.test.js +12 -12
  191. package/lib/projects/__tests__/structure.test.js +3 -3
  192. package/lib/projects/__tests__/upload.test.d.ts +1 -0
  193. package/lib/projects/__tests__/upload.test.js +82 -0
  194. package/lib/projects/add/__tests__/legacyAddComponent.test.js +6 -6
  195. package/lib/projects/add/__tests__/v2AddComponent.test.d.ts +1 -0
  196. package/lib/projects/add/__tests__/{v3AddComponent.test.js → v2AddComponent.test.js} +39 -39
  197. package/lib/projects/add/{v3AddComponent.d.ts → v2AddComponent.d.ts} +1 -1
  198. package/lib/projects/add/{v3AddComponent.js → v2AddComponent.js} +5 -5
  199. package/lib/projects/create/__tests__/legacy.test.js +5 -5
  200. package/lib/projects/create/__tests__/v2.test.d.ts +1 -0
  201. package/lib/projects/create/__tests__/{v3.test.js → v2.test.js} +82 -7
  202. package/lib/projects/create/index.js +4 -4
  203. package/lib/projects/create/legacy.js +2 -2
  204. package/lib/projects/create/{v3.d.ts → v2.d.ts} +3 -3
  205. package/lib/projects/create/{v3.js → v2.js} +16 -13
  206. package/lib/projects/deploy.d.ts +1 -1
  207. package/lib/projects/deploy.js +2 -2
  208. package/lib/projects/localDev/AppDevModeInterface.d.ts +10 -1
  209. package/lib/projects/localDev/AppDevModeInterface.js +118 -89
  210. package/lib/projects/localDev/DevServerManager.d.ts +11 -29
  211. package/lib/projects/localDev/DevServerManager.js +19 -61
  212. package/lib/projects/localDev/DevServerManager_DEPRECATED.d.ts +40 -0
  213. package/lib/projects/localDev/DevServerManager_DEPRECATED.js +120 -0
  214. package/lib/projects/localDev/LocalDevLogger.d.ts +4 -0
  215. package/lib/projects/localDev/LocalDevLogger.js +27 -6
  216. package/lib/projects/localDev/{LocalDevManager.js → LocalDevManager_DEPRECATED.js} +10 -11
  217. package/lib/projects/localDev/LocalDevProcess.d.ts +7 -5
  218. package/lib/projects/localDev/LocalDevProcess.js +93 -21
  219. package/lib/projects/localDev/LocalDevState.d.ts +12 -8
  220. package/lib/projects/localDev/LocalDevState.js +27 -17
  221. package/lib/projects/localDev/LocalDevWebsocketServer.d.ts +6 -1
  222. package/lib/projects/localDev/LocalDevWebsocketServer.js +94 -33
  223. package/lib/projects/localDev/helpers/account.d.ts +1 -1
  224. package/lib/projects/localDev/helpers/account.js +2 -2
  225. package/lib/projects/localDev/helpers/project.d.ts +3 -2
  226. package/lib/projects/localDev/helpers/project.js +49 -10
  227. package/lib/projects/localDev/localDevWebsocketServerUtils.d.ts +7 -0
  228. package/lib/projects/localDev/localDevWebsocketServerUtils.js +19 -0
  229. package/lib/projects/platformVersion.d.ts +1 -1
  230. package/lib/projects/platformVersion.js +1 -1
  231. package/lib/projects/pollProjectBuildAndDeploy.js +4 -4
  232. package/lib/projects/structure.js +6 -6
  233. package/lib/projects/upload.d.ts +1 -1
  234. package/lib/projects/upload.js +17 -8
  235. package/lib/projects/urls.d.ts +0 -1
  236. package/lib/projects/urls.js +0 -3
  237. package/lib/prompts/__tests__/downloadProjectPrompt.test.js +1 -0
  238. package/lib/prompts/__tests__/projectAddPrompt.test.js +10 -10
  239. package/lib/prompts/accountNamePrompt.js +14 -19
  240. package/lib/prompts/accountsPrompt.js +2 -2
  241. package/lib/prompts/cmsFieldPrompt.js +2 -2
  242. package/lib/prompts/createApiSamplePrompt.js +5 -5
  243. package/lib/prompts/createDeveloperTestAccountConfigPrompt.js +10 -1
  244. package/lib/prompts/createFunctionPrompt.js +14 -14
  245. package/lib/prompts/createModulePrompt.js +9 -9
  246. package/lib/prompts/createTemplatePrompt.js +2 -2
  247. package/lib/prompts/downloadProjectPrompt.js +5 -8
  248. package/lib/prompts/installAppPrompt.d.ts +1 -6
  249. package/lib/prompts/installAppPrompt.js +1 -6
  250. package/lib/prompts/personalAccessKeyPrompt.js +3 -3
  251. package/lib/prompts/previewPrompt.js +6 -6
  252. package/lib/prompts/projectAddPrompt.d.ts +2 -2
  253. package/lib/prompts/projectAddPrompt.js +9 -2
  254. package/lib/prompts/projectDevTargetAccountPrompt.js +20 -32
  255. package/lib/prompts/projectNamePrompt.js +4 -8
  256. package/lib/prompts/projectsLogsPrompt.js +2 -4
  257. package/lib/prompts/promptUtils.js +30 -9
  258. package/lib/prompts/sandboxesPrompt.js +7 -7
  259. package/lib/prompts/secretPrompt.js +3 -3
  260. package/lib/prompts/selectAppPrompt.js +3 -3
  261. package/lib/prompts/selectHubDBTablePrompt.js +9 -13
  262. package/lib/prompts/selectProjectTemplatePrompt.js +2 -0
  263. package/lib/prompts/selectPublicAppForMigrationPrompt.js +15 -19
  264. package/lib/prompts/setAsDefaultAccountPrompt.js +4 -8
  265. package/lib/prompts/uploadPrompt.js +5 -5
  266. package/lib/sandboxSync.js +24 -41
  267. package/lib/sandboxes.js +19 -47
  268. package/lib/schema.js +3 -3
  269. package/lib/serverlessLogs.js +11 -13
  270. package/lib/theme/__tests__/migrate.test.d.ts +1 -0
  271. package/lib/theme/__tests__/migrate.test.js +233 -0
  272. package/lib/theme/migrate.d.ts +13 -0
  273. package/lib/theme/migrate.js +90 -0
  274. package/lib/ui/SpinniesManager.d.ts +2 -0
  275. package/lib/ui/SpinniesManager.js +112 -8
  276. package/lib/ui/boxen.js +1 -2
  277. package/lib/ui/git.js +13 -10
  278. package/lib/ui/index.d.ts +4 -0
  279. package/lib/ui/index.js +47 -38
  280. package/lib/ui/serverlessFunctionLogs.js +9 -7
  281. package/lib/ui/uiMessages.d.ts +72 -0
  282. package/lib/ui/uiMessages.js +75 -0
  283. package/lib/usageTracking.js +8 -8
  284. package/lib/validation.js +20 -23
  285. package/lib/yargsUtils.d.ts +1 -1
  286. package/lib/yargsUtils.js +12 -5
  287. package/mcp-server/tools/cms/HsCreateFunctionTool.js +1 -1
  288. package/mcp-server/tools/cms/HsCreateModuleTool.d.ts +2 -2
  289. package/mcp-server/tools/cms/HsCreateModuleTool.js +1 -1
  290. package/mcp-server/tools/cms/HsCreateTemplateTool.js +1 -1
  291. package/mcp-server/tools/cms/HsFunctionLogsTool.js +2 -2
  292. package/mcp-server/tools/cms/HsListFunctionsTool.js +1 -1
  293. package/mcp-server/tools/cms/HsListTool.js +1 -1
  294. package/mcp-server/tools/cms/__tests__/HsCreateFunctionTool.test.js +1 -1
  295. package/mcp-server/tools/cms/__tests__/HsCreateModuleTool.test.js +1 -1
  296. package/mcp-server/tools/cms/__tests__/HsCreateTemplateTool.test.js +1 -1
  297. package/mcp-server/tools/cms/__tests__/HsFunctionLogsTool.test.js +2 -2
  298. package/mcp-server/tools/cms/__tests__/HsListFunctionsTool.test.js +1 -1
  299. package/mcp-server/tools/cms/__tests__/HsListTool.test.js +1 -1
  300. package/mcp-server/tools/index.js +4 -0
  301. package/mcp-server/tools/project/AddFeatureToProjectTool.d.ts +3 -3
  302. package/mcp-server/tools/project/AddFeatureToProjectTool.js +3 -3
  303. package/mcp-server/tools/project/CreateProjectTool.d.ts +3 -3
  304. package/mcp-server/tools/project/CreateProjectTool.js +5 -5
  305. package/mcp-server/tools/project/DeployProjectTool.js +1 -1
  306. package/mcp-server/tools/project/DocFetchTool.js +2 -2
  307. package/mcp-server/tools/project/DocsSearchTool.d.ts +4 -1
  308. package/mcp-server/tools/project/DocsSearchTool.js +7 -7
  309. package/mcp-server/tools/project/GetApiUsagePatternsByAppIdTool.d.ts +23 -0
  310. package/mcp-server/tools/project/GetApiUsagePatternsByAppIdTool.js +68 -0
  311. package/mcp-server/tools/project/GetApplicationInfoTool.d.ts +11 -0
  312. package/mcp-server/tools/project/GetApplicationInfoTool.js +49 -0
  313. package/mcp-server/tools/project/GetConfigValuesTool.d.ts +4 -1
  314. package/mcp-server/tools/project/GetConfigValuesTool.js +13 -7
  315. package/mcp-server/tools/project/GuidedWalkthroughTool.d.ts +2 -2
  316. package/mcp-server/tools/project/GuidedWalkthroughTool.js +1 -1
  317. package/mcp-server/tools/project/UploadProjectTools.js +2 -2
  318. package/mcp-server/tools/project/ValidateProjectTool.js +1 -1
  319. package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.js +1 -1
  320. package/mcp-server/tools/project/__tests__/CreateProjectTool.test.js +2 -2
  321. package/mcp-server/tools/project/__tests__/DeployProjectTool.test.js +1 -1
  322. package/mcp-server/tools/project/__tests__/DocFetchTool.test.js +2 -2
  323. package/mcp-server/tools/project/__tests__/DocsSearchTool.test.js +14 -12
  324. package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.d.ts +1 -0
  325. package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.js +169 -0
  326. package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.d.ts +1 -0
  327. package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.js +115 -0
  328. package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.js +9 -8
  329. package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.js +1 -1
  330. package/mcp-server/tools/project/__tests__/UploadProjectTools.test.js +1 -1
  331. package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.js +1 -1
  332. package/mcp-server/tools/project/constants.d.ts +1 -1
  333. package/mcp-server/tools/project/constants.js +9 -3
  334. package/mcp-server/utils/__tests__/cliConfig.test.d.ts +1 -0
  335. package/mcp-server/utils/__tests__/cliConfig.test.js +110 -0
  336. package/mcp-server/utils/cliConfig.d.ts +1 -0
  337. package/mcp-server/utils/cliConfig.js +12 -0
  338. package/mcp-server/utils/toolUsageTracking.js +2 -2
  339. package/package.json +8 -12
  340. package/types/LocalDev.d.ts +19 -3
  341. package/ui/components/HorizontalSelectPrompt.js +1 -1
  342. package/ui/index.js +1 -1
  343. package/commands/getStartedV2.d.ts +0 -9
  344. package/commands/getStartedV2.js +0 -39
  345. package/lib/middleware/__test__/utils.test.js +0 -51
  346. package/lib/middleware/utils.d.ts +0 -8
  347. package/lib/middleware/utils.js +0 -14
  348. package/lib/projects/localDev/DevServerManagerV2.d.ts +0 -22
  349. package/lib/projects/localDev/DevServerManagerV2.js +0 -81
  350. package/ui/components/Ascii.d.ts +0 -10
  351. package/ui/components/Ascii.js +0 -11
  352. package/ui/views/GetStarted.d.ts +0 -7
  353. package/ui/views/GetStarted.js +0 -157
  354. /package/{lib/middleware/__test__/utils.test.d.ts → commands/project/__tests__/list.test.d.ts} +0 -0
  355. /package/{lib/projects/add/__tests__/v3AddComponent.test.d.ts → commands/project/__tests__/validate.test.d.ts} +0 -0
  356. /package/lib/{projects/create/__tests__/v3.test.d.ts → middleware/__test__/commandTargetingUtils.test.d.ts} +0 -0
  357. /package/lib/projects/localDev/{LocalDevManager.d.ts → LocalDevManager_DEPRECATED.d.ts} +0 -0
@@ -1,25 +1,22 @@
1
1
  import fs from 'fs';
2
- import { logger } from '@hubspot/local-dev-lib/logger';
3
2
  import { loadConfig, getConfigPath, deleteAccount, getConfigDefaultAccount, getAccountId, updateDefaultAccount, getCWDAccountOverride, getDefaultAccountOverrideFilePath, } from '@hubspot/local-dev-lib/config';
4
3
  import { trackCommandUsage } from '../../lib/usageTracking.js';
5
- import { i18n } from '../../lib/lang.js';
6
4
  import { promptUser } from '../../lib/prompts/promptUtils.js';
7
5
  import { logError } from '../../lib/errorHandlers/index.js';
8
6
  import { selectAccountFromConfig } from '../../lib/prompts/accountsPrompt.js';
9
7
  import { makeYargsBuilder } from '../../lib/yargsUtils.js';
8
+ import { uiLogger } from '../../lib/ui/logger.js';
9
+ import { commands } from '../../lang/en.js';
10
10
  const command = 'remove [account]';
11
- const describe = i18n(`commands.account.subcommands.remove.describe`);
11
+ const describe = commands.account.subcommands.remove.describe;
12
12
  async function handler(args) {
13
13
  const { account } = args;
14
14
  let accountToRemove = account;
15
15
  if (accountToRemove && !getAccountId(accountToRemove)) {
16
- logger.error(i18n(`commands.account.subcommands.remove.errors.accountNotFound`, {
17
- specifiedAccount: accountToRemove,
18
- configPath: getConfigPath(),
19
- }));
16
+ uiLogger.error(commands.account.subcommands.remove.errors.accountNotFound(accountToRemove, getConfigPath()));
20
17
  }
21
18
  if (!accountToRemove || !getAccountId(accountToRemove)) {
22
- accountToRemove = await selectAccountFromConfig(i18n(`commands.account.subcommands.remove.prompts.selectAccountToRemove`));
19
+ accountToRemove = await selectAccountFromConfig(commands.account.subcommands.remove.prompts.selectAccountToRemove);
23
20
  }
24
21
  trackCommandUsage('accounts-remove', undefined, getAccountId(accountToRemove));
25
22
  const currentDefaultAccount = getConfigDefaultAccount();
@@ -31,10 +28,7 @@ async function handler(args) {
31
28
  const { deleteOverrideFile } = await promptUser({
32
29
  type: 'confirm',
33
30
  name: 'deleteOverrideFile',
34
- message: i18n(`commands.account.subcommands.remove.prompts.deleteOverrideFile`, {
35
- overrideFilePath,
36
- accountName: accountToRemove,
37
- }),
31
+ message: commands.account.subcommands.remove.prompts.deleteOverrideFile(overrideFilePath, accountToRemove),
38
32
  });
39
33
  try {
40
34
  if (deleteOverrideFile) {
@@ -46,9 +40,7 @@ async function handler(args) {
46
40
  }
47
41
  }
48
42
  await deleteAccount(accountToRemove);
49
- logger.success(i18n(`commands.account.subcommands.remove.success.accountRemoved`, {
50
- accountName: accountToRemove,
51
- }));
43
+ uiLogger.success(commands.account.subcommands.remove.success.accountRemoved(accountToRemove));
52
44
  // Get updated version of the config
53
45
  loadConfig(getConfigPath());
54
46
  const accountToRemoveId = getAccountId(accountToRemove);
@@ -57,25 +49,25 @@ async function handler(args) {
57
49
  defaultAccountId = getAccountId(currentDefaultAccount);
58
50
  }
59
51
  if (accountToRemoveId === defaultAccountId) {
60
- logger.log();
61
- logger.log(i18n(`commands.account.subcommands.remove.logs.replaceDefaultAccount`));
52
+ uiLogger.log('');
53
+ uiLogger.log(commands.account.subcommands.remove.logs.replaceDefaultAccount);
62
54
  const newDefaultAccount = await selectAccountFromConfig();
63
55
  updateDefaultAccount(newDefaultAccount);
64
56
  }
65
57
  }
66
58
  function accountRemoveBuilder(yargs) {
67
59
  yargs.positional('account', {
68
- describe: i18n(`commands.account.subcommands.remove.options.account.describe`),
60
+ describe: commands.account.subcommands.remove.options.account.describe,
69
61
  type: 'string',
70
62
  });
71
63
  yargs.example([
72
64
  [
73
65
  '$0 accounts remove',
74
- i18n(`commands.account.subcommands.remove.examples.default`),
66
+ commands.account.subcommands.remove.examples.default,
75
67
  ],
76
68
  [
77
69
  '$0 accounts remove MyAccount',
78
- i18n(`commands.account.subcommands.remove.examples.byName`),
70
+ commands.account.subcommands.remove.examples.byName,
79
71
  ],
80
72
  ]);
81
73
  return yargs;
@@ -1,26 +1,21 @@
1
1
  import fs from 'fs-extra';
2
- import { logger } from '@hubspot/local-dev-lib/logger';
3
2
  import { getCWDAccountOverride, getDefaultAccountOverrideFilePath, getAccountId, } from '@hubspot/local-dev-lib/config';
4
3
  import { DEFAULT_ACCOUNT_OVERRIDE_FILE_NAME } from '@hubspot/local-dev-lib/constants/config';
5
4
  import { getGlobalConfig } from '@hubspot/local-dev-lib/config/migrate';
6
- import { i18n } from '../../lib/lang.js';
7
5
  import { promptUser } from '../../lib/prompts/promptUtils.js';
8
6
  import { trackCommandMetadataUsage } from '../../lib/usageTracking.js';
9
7
  import { EXIT_CODES } from '../../lib/enums/exitCodes.js';
10
8
  import { logError } from '../../lib/errorHandlers/index.js';
11
- import { uiCommandReference } from '../../lib/ui/index.js';
12
9
  import { makeYargsBuilder } from '../../lib/yargsUtils.js';
10
+ import { uiLogger } from '../../lib/ui/logger.js';
11
+ import { commands } from '../../lang/en.js';
13
12
  const command = 'remove-override';
14
- const describe = i18n('commands.account.subcommands.removeOverride.describe', {
15
- overrideFile: DEFAULT_ACCOUNT_OVERRIDE_FILE_NAME,
16
- });
13
+ const describe = commands.account.subcommands.removeOverride.describe(DEFAULT_ACCOUNT_OVERRIDE_FILE_NAME);
17
14
  async function handler(args) {
18
15
  const { force } = args;
19
16
  const globalConfig = getGlobalConfig();
20
17
  if (!globalConfig) {
21
- logger.error(i18n('commands.account.subcommands.createOverride.errors.globalConfigNotFound', {
22
- authCommand: uiCommandReference('hs account auth'),
23
- }));
18
+ uiLogger.error(commands.account.subcommands.removeOverride.errors.globalConfigNotFound);
24
19
  process.exit(EXIT_CODES.ERROR);
25
20
  }
26
21
  const accountOverride = getCWDAccountOverride();
@@ -28,19 +23,14 @@ async function handler(args) {
28
23
  if (accountOverride && overrideFilePath) {
29
24
  const accountId = getAccountId(accountOverride) || undefined;
30
25
  if (!force) {
31
- logger.log(i18n('commands.account.subcommands.removeOverride.accountOverride', {
32
- accountOverride,
33
- overrideFilePath,
34
- }));
26
+ uiLogger.log(commands.account.subcommands.removeOverride.accountOverride(overrideFilePath, accountOverride.toString()));
35
27
  const { deleteOverrideFile } = await promptUser({
36
28
  type: 'confirm',
37
29
  name: 'deleteOverrideFile',
38
- message: i18n('commands.account.subcommands.removeOverride.prompts.deleteOverrideFile', {
39
- accountOverride,
40
- overrideFilePath,
41
- }),
30
+ message: commands.account.subcommands.removeOverride.prompts
31
+ .deleteOverrideFile,
42
32
  });
43
- logger.log('');
33
+ uiLogger.log('');
44
34
  if (!deleteOverrideFile) {
45
35
  trackCommandMetadataUsage('account-removeOverride', {
46
36
  command: 'hs account remove-override',
@@ -51,7 +41,7 @@ async function handler(args) {
51
41
  }
52
42
  try {
53
43
  fs.unlinkSync(overrideFilePath);
54
- logger.success(i18n('commands.account.subcommands.removeOverride.success'));
44
+ uiLogger.success(commands.account.subcommands.removeOverride.success);
55
45
  trackCommandMetadataUsage('account-removeOverride', {
56
46
  command: 'hs account remove-override',
57
47
  step: 'Confirm removing override file (via prompt/force)',
@@ -65,13 +55,13 @@ async function handler(args) {
65
55
  }
66
56
  }
67
57
  else {
68
- logger.log(i18n('commands.account.subcommands.removeOverride.noOverrideFile'));
58
+ uiLogger.log(commands.account.subcommands.removeOverride.noOverrideFile);
69
59
  process.exit(EXIT_CODES.SUCCESS);
70
60
  }
71
61
  }
72
62
  function accountRemoveOverrideBuilder(yargs) {
73
63
  yargs.options('force', {
74
- describe: i18n('commands.account.subcommands.removeOverride.options.force.describe'),
64
+ describe: commands.account.subcommands.removeOverride.options.force.describe,
75
65
  type: 'boolean',
76
66
  });
77
67
  return yargs;
@@ -1,12 +1,12 @@
1
- import { logger } from '@hubspot/local-dev-lib/logger';
2
1
  import { renameAccount } from '@hubspot/local-dev-lib/config';
3
2
  import { trackCommandUsage } from '../../lib/usageTracking.js';
4
- import { i18n } from '../../lib/lang.js';
3
+ import { commands } from '../../lang/en.js';
4
+ import { uiLogger } from '../../lib/ui/logger.js';
5
5
  import { logError } from '../../lib/errorHandlers/index.js';
6
6
  import { EXIT_CODES } from '../../lib/enums/exitCodes.js';
7
7
  import { makeYargsBuilder } from '../../lib/yargsUtils.js';
8
8
  const command = 'rename <account-name> <new-name>';
9
- const describe = i18n(`commands.account.subcommands.rename.describe`);
9
+ const describe = commands.account.subcommands.rename.describe;
10
10
  async function handler(args) {
11
11
  const { accountName, newName, derivedAccountId } = args;
12
12
  trackCommandUsage('accounts-rename', undefined, derivedAccountId);
@@ -17,19 +17,16 @@ async function handler(args) {
17
17
  logError(error);
18
18
  process.exit(EXIT_CODES.ERROR);
19
19
  }
20
- logger.log(i18n(`commands.account.subcommands.rename.success.renamed`, {
21
- name: accountName,
22
- newName,
23
- }));
20
+ uiLogger.log(commands.account.subcommands.rename.success.renamed(accountName, newName));
24
21
  process.exit(EXIT_CODES.SUCCESS);
25
22
  }
26
23
  function accountRenameBuilder(yargs) {
27
24
  yargs.positional('account-name', {
28
- describe: i18n(`commands.account.subcommands.rename.positionals.accountName.describe`),
25
+ describe: commands.account.subcommands.rename.positionals.accountName.describe,
29
26
  type: 'string',
30
27
  });
31
28
  yargs.positional('new-name', {
32
- describe: i18n(`commands.account.subcommands.rename.positionals.newName.describe`),
29
+ describe: commands.account.subcommands.rename.positionals.newName.describe,
33
30
  type: 'string',
34
31
  });
35
32
  yargs.example([
@@ -1,59 +1,45 @@
1
- import { logger } from '@hubspot/local-dev-lib/logger';
2
1
  import { getConfigPath, updateDefaultAccount, getAccountId, getCWDAccountOverride, getDefaultAccountOverrideFilePath, } from '@hubspot/local-dev-lib/config';
3
2
  import { trackCommandUsage } from '../../lib/usageTracking.js';
4
- import { i18n } from '../../lib/lang.js';
3
+ import { commands } from '../../lang/en.js';
4
+ import { uiLogger } from '../../lib/ui/logger.js';
5
5
  import { selectAccountFromConfig } from '../../lib/prompts/accountsPrompt.js';
6
- import { uiCommandReference } from '../../lib/ui/index.js';
7
6
  import { makeYargsBuilder } from '../../lib/yargsUtils.js';
8
7
  const command = 'use [account]';
9
- const describe = i18n('commands.account.subcommands.use.describe');
8
+ const describe = commands.account.subcommands.use.describe;
10
9
  async function handler(args) {
11
10
  let newDefaultAccount = args.account;
12
11
  if (!newDefaultAccount) {
13
12
  newDefaultAccount = await selectAccountFromConfig();
14
13
  }
15
14
  else if (!getAccountId(newDefaultAccount)) {
16
- logger.error(i18n('commands.account.subcommands.use.errors.accountNotFound', {
17
- specifiedAccount: newDefaultAccount,
18
- configPath: getConfigPath(),
19
- }));
15
+ uiLogger.error(commands.account.subcommands.use.errors.accountNotFound(newDefaultAccount, getConfigPath()));
20
16
  newDefaultAccount = await selectAccountFromConfig();
21
17
  }
22
18
  trackCommandUsage('accounts-use', undefined, getAccountId(newDefaultAccount));
23
19
  const accountOverride = getCWDAccountOverride();
24
20
  const overrideFilePath = getDefaultAccountOverrideFilePath();
25
21
  if (accountOverride && overrideFilePath) {
26
- logger.warn(i18n(`commands.account.subcommands.use.accountOverride`, {
27
- accountOverride,
28
- }));
29
- logger.log(i18n(`commands.account.subcommands.use.accountOverrideCommands`, {
30
- createOverrideCommand: uiCommandReference('hs account create-override'),
31
- removeOverrideCommand: uiCommandReference('hs account remove-override'),
32
- }));
33
- logger.log('');
22
+ uiLogger.warn(commands.account.subcommands.use.accountOverride(accountOverride.toString()));
23
+ uiLogger.log(commands.account.subcommands.use.accountOverrideCommands);
24
+ uiLogger.log('');
34
25
  }
35
26
  updateDefaultAccount(newDefaultAccount);
36
- return logger.success(i18n('commands.account.subcommands.use.success.defaultAccountUpdated', {
37
- accountName: newDefaultAccount,
38
- }));
27
+ return uiLogger.success(commands.account.subcommands.use.success.defaultAccountUpdated(newDefaultAccount));
39
28
  }
40
29
  function accountUseBuilder(yargs) {
41
30
  yargs.positional('account', {
42
- describe: i18n('commands.account.subcommands.use.options.account.describe'),
31
+ describe: commands.account.subcommands.use.options.account.describe,
43
32
  type: 'string',
44
33
  });
45
34
  yargs.example([
46
- [
47
- '$0 accounts use',
48
- i18n('commands.account.subcommands.use.examples.default'),
49
- ],
35
+ ['$0 accounts use', commands.account.subcommands.use.examples.default],
50
36
  [
51
37
  '$0 accounts use MyAccount',
52
- i18n('commands.account.subcommands.use.examples.nameBased'),
38
+ commands.account.subcommands.use.examples.nameBased,
53
39
  ],
54
40
  [
55
41
  '$0 accounts use 1234567',
56
- i18n('commands.account.subcommands.use.examples.idBased'),
42
+ commands.account.subcommands.use.examples.idBased,
57
43
  ],
58
44
  ]);
59
45
  return yargs;
@@ -1,4 +1,4 @@
1
- import { i18n } from '../lib/lang.js';
1
+ import { commands } from '../lang/en.js';
2
2
  import auth from './account/auth.js';
3
3
  import list from './account/list.js';
4
4
  import rename from './account/rename.js';
@@ -10,7 +10,7 @@ import createOverride from './account/createOverride.js';
10
10
  import removeOverride from './account/removeOverride.js';
11
11
  import { makeYargsBuilder } from '../lib/yargsUtils.js';
12
12
  const command = ['account', 'accounts'];
13
- const describe = i18n('commands.account.describe');
13
+ const describe = commands.account.describe;
14
14
  function accountBuilder(yargs) {
15
15
  yargs
16
16
  .command(auth)
@@ -1,13 +1,13 @@
1
1
  import yargs from 'yargs';
2
2
  import { PLATFORM_VERSIONS } from '@hubspot/local-dev-lib/constants/projects';
3
- import { logger } from '@hubspot/local-dev-lib/logger';
3
+ import { uiLogger } from '../../../lib/ui/logger.js';
4
4
  import { getAccountConfig } from '@hubspot/local-dev-lib/config';
5
5
  import { migrateApp2025_2 } from '../../../lib/app/migrate.js';
6
6
  import { migrateApp2023_2 } from '../../../lib/app/migrate_legacy.js';
7
7
  import { EXIT_CODES } from '../../../lib/enums/exitCodes.js';
8
8
  import migrateCommand from '../migrate.js';
9
9
  vi.mock('@hubspot/local-dev-lib/config');
10
- vi.mock('@hubspot/local-dev-lib/logger');
10
+ vi.mock('../../../lib/ui/logger.js');
11
11
  vi.mock('../../../lib/app/migrate');
12
12
  vi.mock('../../../lib/app/migrate_legacy');
13
13
  vi.mock('../../../lib/projects/config.js');
@@ -15,7 +15,7 @@ const mockYargs = yargs;
15
15
  const mockedGetAccountConfig = getAccountConfig;
16
16
  const mockedMigrateApp2023_2 = migrateApp2023_2;
17
17
  const mockedMigrateApp2025_2 = migrateApp2025_2;
18
- const mockedLogger = logger;
18
+ const mockedUiLogger = uiLogger;
19
19
  const optionsSpy = vi.spyOn(mockYargs, 'options');
20
20
  const exampleSpy = vi.spyOn(mockYargs, 'example');
21
21
  const exitSpy = vi
@@ -40,7 +40,7 @@ describe('commands/app/migrate', () => {
40
40
  await migrateCommand.handler({
41
41
  derivedAccountId: mockAccountId,
42
42
  });
43
- expect(mockedLogger.error).toHaveBeenCalled();
43
+ expect(mockedUiLogger.error).toHaveBeenCalled();
44
44
  expect(exitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
45
45
  });
46
46
  it('should call migrateApp2025_2 for platform version 2025.2', async () => {
@@ -80,7 +80,7 @@ describe('commands/app/migrate', () => {
80
80
  derivedAccountId: mockAccountId,
81
81
  platformVersion: PLATFORM_VERSIONS.v2023_2,
82
82
  });
83
- expect(mockedLogger.error).toHaveBeenCalled();
83
+ expect(mockedUiLogger.error).toHaveBeenCalled();
84
84
  expect(exitSpy).toHaveBeenCalledWith(EXIT_CODES.ERROR);
85
85
  });
86
86
  });
@@ -103,7 +103,6 @@ describe('commands/app/migrate', () => {
103
103
  'platform-version': expect.objectContaining({
104
104
  type: 'string',
105
105
  default: '2025.2',
106
- hidden: true,
107
106
  }),
108
107
  }));
109
108
  });
@@ -1,35 +1,33 @@
1
- import { logger } from '@hubspot/local-dev-lib/logger';
2
1
  import { getAccountConfig } from '@hubspot/local-dev-lib/config';
3
2
  import { PLATFORM_VERSIONS } from '@hubspot/local-dev-lib/constants/projects';
4
3
  import { trackCommandMetadataUsage, trackCommandUsage, } from '../../lib/usageTracking.js';
5
- import { i18n } from '../../lib/lang.js';
4
+ import { commands } from '../../lang/en.js';
5
+ import { uiLogger } from '../../lib/ui/logger.js';
6
6
  import { ApiErrorContext, logError } from '../../lib/errorHandlers/index.js';
7
7
  import { EXIT_CODES } from '../../lib/enums/exitCodes.js';
8
8
  import { migrateApp2025_2 } from '../../lib/app/migrate.js';
9
- import { uiBetaTag, uiCommandReference, uiLink } from '../../lib/ui/index.js';
10
9
  import { migrateApp2023_2 } from '../../lib/app/migrate_legacy.js';
11
10
  import { getIsInProject } from '../../lib/projects/config.js';
12
11
  import { makeYargsBuilder } from '../../lib/yargsUtils.js';
13
12
  const { v2023_2, v2025_2 } = PLATFORM_VERSIONS;
14
13
  const command = 'migrate';
15
- const describe = undefined; // uiBetaTag(i18n(`commands.project.subcommands.migrateApp.header.text.describe`), false);
14
+ const describe = commands.project.migrateApp.describe;
16
15
  export function handlerGenerator(commandTrackingName) {
17
16
  return async function handler(args) {
18
17
  const { derivedAccountId, platformVersion, unstable } = args;
19
18
  await trackCommandUsage(commandTrackingName, {}, derivedAccountId);
20
19
  const accountConfig = getAccountConfig(derivedAccountId);
21
20
  if (!accountConfig) {
22
- logger.error(i18n(`commands.project.subcommands.migrateApp.errors.noAccountConfig`));
21
+ uiLogger.error(commands.project.migrateApp.errors.noAccountConfig);
23
22
  return process.exit(EXIT_CODES.ERROR);
24
23
  }
25
- logger.log('');
26
- logger.log(uiBetaTag(i18n(`commands.project.subcommands.migrateApp.header.text`), false));
27
- logger.log(uiLink(i18n(`commands.project.subcommands.migrateApp.header.link`), 'https://developers.hubspot.com/docs/platform/migrate-a-public-app-to-projects'));
28
- logger.log('');
24
+ uiLogger.log('');
25
+ uiLogger.log(commands.project.migrateApp.header);
26
+ uiLogger.log('');
29
27
  try {
30
28
  if (platformVersion === v2025_2 || unstable) {
31
29
  if (getIsInProject()) {
32
- logger.error(i18n(`commands.project.subcommands.migrateApp.errors.notAllowedWithinProject`, { command: uiCommandReference('hs project migrate') }));
30
+ uiLogger.error(commands.project.migrateApp.errors.notAllowedWithinProject);
33
31
  return process.exit(EXIT_CODES.ERROR);
34
32
  }
35
33
  args.platformVersion = unstable
@@ -62,21 +60,20 @@ const handler = handlerGenerator('app-migrate');
62
60
  function appMigrateBuilder(yargs) {
63
61
  yargs.options({
64
62
  name: {
65
- describe: i18n(`commands.project.subcommands.migrateApp.options.name.describe`),
63
+ describe: commands.project.migrateApp.options.name.describe,
66
64
  type: 'string',
67
65
  },
68
66
  dest: {
69
- describe: i18n(`commands.project.subcommands.migrateApp.options.dest.describe`),
67
+ describe: commands.project.migrateApp.options.dest.describe,
70
68
  type: 'string',
71
69
  },
72
70
  'app-id': {
73
- describe: i18n(`commands.project.subcommands.migrateApp.options.appId.describe`),
71
+ describe: commands.project.migrateApp.options.appId.describe,
74
72
  type: 'number',
75
73
  },
76
74
  'platform-version': {
77
75
  type: 'string',
78
76
  choices: [v2023_2, v2025_2],
79
- hidden: true,
80
77
  default: v2025_2,
81
78
  },
82
79
  unstable: {
@@ -86,14 +83,11 @@ function appMigrateBuilder(yargs) {
86
83
  },
87
84
  });
88
85
  yargs.example([
89
- [
90
- `$0 app migrate`,
91
- i18n(`commands.project.subcommands.migrateApp.examples.default`),
92
- ],
86
+ [`$0 app migrate`, commands.project.migrateApp.examples.default],
93
87
  ]);
94
88
  return yargs;
95
89
  }
96
- const builder = makeYargsBuilder(appMigrateBuilder, command, uiBetaTag(i18n(`commands.project.subcommands.migrateApp.describe`), false), {
90
+ const builder = makeYargsBuilder(appMigrateBuilder, command, commands.project.migrateApp.describe, {
97
91
  useGlobalOptions: true,
98
92
  useConfigOptions: true,
99
93
  useAccountOptions: true,
@@ -7,8 +7,9 @@ import { commands } from '../../../lang/en.js';
7
7
  import { EXIT_CODES } from '../../../lib/enums/exitCodes.js';
8
8
  import { makeYargsBuilder } from '../../../lib/yargsUtils.js';
9
9
  import { uiLogger } from '../../../lib/ui/logger.js';
10
+ import { uiBetaTag } from '../../../lib/ui/index.js';
10
11
  const command = 'add [name]';
11
- const describe = commands.app.subcommands.secret.subcommands.add.describe;
12
+ const describe = uiBetaTag(commands.app.subcommands.secret.subcommands.add.describe, false);
12
13
  async function handler(args) {
13
14
  const { derivedAccountId } = args;
14
15
  trackCommandUsage('app-secret-add', {}, derivedAccountId);
@@ -7,8 +7,9 @@ import { commands } from '../../../lang/en.js';
7
7
  import { EXIT_CODES } from '../../../lib/enums/exitCodes.js';
8
8
  import { makeYargsBuilder } from '../../../lib/yargsUtils.js';
9
9
  import { uiLogger } from '../../../lib/ui/logger.js';
10
+ import { uiBetaTag } from '../../../lib/ui/index.js';
10
11
  const command = 'delete [name]';
11
- const describe = commands.app.subcommands.secret.subcommands.delete.describe;
12
+ const describe = uiBetaTag(commands.app.subcommands.secret.subcommands.delete.describe, false);
12
13
  async function handler(args) {
13
14
  const { derivedAccountId, force } = args;
14
15
  trackCommandUsage('app-secret-delete', {}, derivedAccountId);
@@ -6,8 +6,9 @@ import { EXIT_CODES } from '../../../lib/enums/exitCodes.js';
6
6
  import { makeYargsBuilder } from '../../../lib/yargsUtils.js';
7
7
  import { selectAppPrompt } from '../../../lib/prompts/selectAppPrompt.js';
8
8
  import { uiLogger } from '../../../lib/ui/logger.js';
9
+ import { uiBetaTag } from '../../../lib/ui/index.js';
9
10
  const command = 'list';
10
- const describe = commands.app.subcommands.secret.subcommands.list.describe;
11
+ const describe = uiBetaTag(commands.app.subcommands.secret.subcommands.list.describe, false);
11
12
  async function handler(args) {
12
13
  const { derivedAccountId } = args;
13
14
  trackCommandUsage('app-secret-list', {}, derivedAccountId);
@@ -8,8 +8,9 @@ import { commands } from '../../../lang/en.js';
8
8
  import { EXIT_CODES } from '../../../lib/enums/exitCodes.js';
9
9
  import { makeYargsBuilder } from '../../../lib/yargsUtils.js';
10
10
  import { uiLogger } from '../../../lib/ui/logger.js';
11
+ import { uiBetaTag } from '../../../lib/ui/index.js';
11
12
  const command = 'update [name]';
12
- const describe = commands.app.subcommands.secret.subcommands.update.describe;
13
+ const describe = uiBetaTag(commands.app.subcommands.secret.subcommands.update.describe, false);
13
14
  async function handler(args) {
14
15
  const { derivedAccountId } = args;
15
16
  trackCommandUsage('app-secret-update', {}, derivedAccountId);
@@ -4,8 +4,9 @@ import addAppSecretCommand from './secret/add.js';
4
4
  import deleteAppSecretCommand from './secret/delete.js';
5
5
  import listAppSecretsCommand from './secret/list.js';
6
6
  import updateAppSecretCommand from './secret/update.js';
7
+ import { uiBetaTag } from '../../lib/ui/index.js';
7
8
  const command = ['secret', 'secrets'];
8
- const describe = undefined; // commands.app.subcommands.secret.describe;
9
+ const describe = uiBetaTag(commands.app.subcommands.secret.describe, false);
9
10
  function appSecretBuilder(yargs) {
10
11
  yargs
11
12
  .command(addAppSecretCommand)
package/commands/app.js CHANGED
@@ -1,9 +1,9 @@
1
1
  import migrateCommand from './app/migrate.js';
2
2
  import appSecretCommand from './app/secret.js';
3
3
  import { makeYargsBuilder } from '../lib/yargsUtils.js';
4
+ import { commands } from '../lang/en.js';
4
5
  const command = ['app', 'apps'];
5
- // Keep the command hidden for now
6
- const describe = undefined;
6
+ const describe = commands.app.describe;
7
7
  function appBuilder(yargs) {
8
8
  yargs.command(migrateCommand).command(appSecretCommand).demandCommand(1, '');
9
9
  return yargs;
@@ -1,6 +1,7 @@
1
1
  import { AccountArgs, CommonArgs, ConfigArgs, TestingArgs, YargsCommandModule } from '../types/Yargs.js';
2
2
  type AuthArgs = CommonArgs & ConfigArgs & TestingArgs & AccountArgs & {
3
3
  authType?: string;
4
+ disableTracking: boolean;
4
5
  } & {
5
6
  personalAccessKey?: string;
6
7
  };
package/commands/auth.js CHANGED
@@ -9,7 +9,7 @@ import { promptUser } from '../lib/prompts/promptUtils.js';
9
9
  import { personalAccessKeyPrompt, OAUTH_FLOW, } from '../lib/prompts/personalAccessKeyPrompt.js';
10
10
  import { cliAccountNamePrompt } from '../lib/prompts/accountNamePrompt.js';
11
11
  import { setAsDefaultAccountPrompt } from '../lib/prompts/setAsDefaultAccountPrompt.js';
12
- import { setLogLevel } from '../lib/commonOpts.js';
12
+ import { setCLILogLevel } from '../lib/commonOpts.js';
13
13
  import { makeYargsBuilder } from '../lib/yargsUtils.js';
14
14
  import { trackAuthAction, trackCommandUsage } from '../lib/usageTracking.js';
15
15
  import { authenticateWithOauth } from '../lib/oauth.js';
@@ -32,7 +32,7 @@ const SUPPORTED_AUTHENTICATION_PROTOCOLS_TEXT = commaSeparatedValues(ALLOWED_AUT
32
32
  const command = 'auth';
33
33
  const describe = commands.auth.describe;
34
34
  async function handler(args) {
35
- const { authType: authTypeFlagValue, config: configFlagValue, qa, personalAccessKey: providedPersonalAccessKey, userProvidedAccount, } = args;
35
+ const { authType: authTypeFlagValue, config: configFlagValue, qa, personalAccessKey: providedPersonalAccessKey, userProvidedAccount, disableTracking, } = args;
36
36
  let parsedUserProvidedAccountId;
37
37
  try {
38
38
  if (userProvidedAccount) {
@@ -45,7 +45,7 @@ async function handler(args) {
45
45
  }
46
46
  const authType = (authTypeFlagValue && authTypeFlagValue.toLowerCase()) ||
47
47
  PERSONAL_ACCESS_KEY_AUTH_METHOD.value;
48
- setLogLevel(args);
48
+ setCLILogLevel(args);
49
49
  const env = qa ? ENVIRONMENTS.QA : ENVIRONMENTS.PROD;
50
50
  // Needed to load deprecated config
51
51
  loadConfig(configFlagValue);
@@ -57,8 +57,10 @@ async function handler(args) {
57
57
  uiLogger.error(commands.auth.errors.globalConfigFileExists('hs account auth'));
58
58
  process.exit(EXIT_CODES.ERROR);
59
59
  }
60
- trackCommandUsage('auth');
61
- trackAuthAction('auth', authType, TRACKING_STATUS.STARTED, parsedUserProvidedAccountId);
60
+ if (!disableTracking) {
61
+ trackCommandUsage('auth');
62
+ trackAuthAction('auth', authType, TRACKING_STATUS.STARTED, parsedUserProvidedAccountId);
63
+ }
62
64
  let configData;
63
65
  let updatedConfig;
64
66
  let validName;
@@ -110,7 +112,7 @@ async function handler(args) {
110
112
  uiLogger.error(commands.auth.errors.unsupportedAuthType(authType, SUPPORTED_AUTHENTICATION_PROTOCOLS_TEXT));
111
113
  break;
112
114
  }
113
- if (!successAuthMethod) {
115
+ if (!successAuthMethod && !disableTracking) {
114
116
  await trackAuthAction('auth', authType, TRACKING_STATUS.ERROR, parsedUserProvidedAccountId);
115
117
  process.exit(EXIT_CODES.ERROR);
116
118
  }
@@ -119,12 +121,15 @@ async function handler(args) {
119
121
  await setAsDefaultAccountPrompt(accountName);
120
122
  uiLogger.success(commands.auth.success.configFileUpdated(accountName, DEFAULT_HUBSPOT_CONFIG_YAML_FILE_NAME, successAuthMethod));
121
123
  uiFeatureHighlight([
124
+ 'getStartedCommand',
122
125
  'accountsUseCommand',
123
126
  'accountOption',
124
127
  'accountsListCommand',
125
128
  ]);
126
129
  const accountId = getAccountId(accountName) || undefined;
127
- await trackAuthAction('auth', authType, TRACKING_STATUS.COMPLETE, accountId);
130
+ if (!disableTracking) {
131
+ await trackAuthAction('auth', authType, TRACKING_STATUS.COMPLETE, accountId);
132
+ }
128
133
  process.exit(EXIT_CODES.SUCCESS);
129
134
  }
130
135
  function authBuilder(yargs) {
@@ -149,6 +154,11 @@ function authBuilder(yargs) {
149
154
  hidden: false,
150
155
  alias: 'pak',
151
156
  },
157
+ 'disable-tracking': {
158
+ type: 'boolean',
159
+ hidden: true,
160
+ default: false,
161
+ },
152
162
  });
153
163
  return yargs;
154
164
  }
@@ -2,21 +2,19 @@ import path from 'path';
2
2
  import fs from 'fs';
3
3
  import { createIgnoreFilter } from '@hubspot/local-dev-lib/ignoreRules';
4
4
  import { isAllowedExtension, getCwd } from '@hubspot/local-dev-lib/path';
5
- import { logger } from '@hubspot/local-dev-lib/logger';
6
5
  import { walk } from '@hubspot/local-dev-lib/fs';
7
6
  import { getThemeJSONPath } from '@hubspot/local-dev-lib/cms/themes';
8
- import { i18n } from '../../lib/lang.js';
7
+ import { commands } from '../../lang/en.js';
8
+ import { uiLogger } from '../../lib/ui/logger.js';
9
9
  import { FieldsJs, isConvertableFieldJs, } from '@hubspot/local-dev-lib/cms/handleFieldsJS';
10
10
  import { trackConvertFieldsUsage } from '../../lib/usageTracking.js';
11
11
  import { logError } from '../../lib/errorHandlers/index.js';
12
12
  import { EXIT_CODES } from '../../lib/enums/exitCodes.js';
13
13
  import { makeYargsBuilder } from '../../lib/yargsUtils.js';
14
14
  const command = 'convert-fields';
15
- const describe = i18n(`commands.convertFields.describe`);
15
+ const describe = commands.convertFields.describe;
16
16
  function invalidPath(src) {
17
- logger.error(i18n(`commands.convertFields.errors.invalidPath`, {
18
- path: src,
19
- }));
17
+ uiLogger.error(commands.convertFields.errors.invalidPath(src));
20
18
  process.exit(EXIT_CODES.ERROR);
21
19
  }
22
20
  async function handler(args) {
@@ -77,13 +75,13 @@ async function handler(args) {
77
75
  }
78
76
  function convertFieldsBuilder(yargs) {
79
77
  yargs.option('src', {
80
- describe: i18n(`commands.convertFields.positionals.src.describe`),
78
+ describe: commands.convertFields.positionals.src.describe,
81
79
  type: 'string',
82
80
  required: true,
83
- demandOption: i18n(`commands.convertFields.errors.missingSrc`),
81
+ demandOption: commands.convertFields.errors.missingSrc,
84
82
  });
85
83
  yargs.option('fieldOptions', {
86
- describe: i18n(`commands.convertFields.options.options.describe`),
84
+ describe: commands.convertFields.options.options.describe,
87
85
  type: 'array',
88
86
  default: [''],
89
87
  });