@hubspot/cli 7.7.20-experimental.0 → 7.7.21-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 (563) hide show
  1. package/api/__tests__/migrate.test.js +27 -29
  2. package/api/migrate.js +14 -22
  3. package/bin/cli.js +92 -97
  4. package/bin/hs +2 -2
  5. package/bin/hscms +2 -2
  6. package/bin/silenceErrors.js +1 -2
  7. package/commands/__tests__/account.test.js +29 -34
  8. package/commands/__tests__/auth.test.js +11 -16
  9. package/commands/__tests__/cms.test.js +15 -20
  10. package/commands/__tests__/config.test.js +14 -19
  11. package/commands/__tests__/create.test.js +10 -15
  12. package/commands/__tests__/customObject.test.js +14 -19
  13. package/commands/__tests__/doctor.test.js +43 -48
  14. package/commands/__tests__/feedback.test.js +7 -45
  15. package/commands/__tests__/fetch.test.js +29 -28
  16. package/commands/__tests__/filemanager.test.js +14 -19
  17. package/commands/__tests__/function.test.js +16 -21
  18. package/commands/__tests__/getStarted.test.js +48 -53
  19. package/commands/__tests__/hubdb.test.js +17 -22
  20. package/commands/__tests__/init.test.js +12 -17
  21. package/commands/__tests__/lint.test.js +13 -18
  22. package/commands/__tests__/list.test.js +18 -23
  23. package/commands/__tests__/logs.test.js +28 -27
  24. package/commands/__tests__/mcp.test.js +14 -19
  25. package/commands/__tests__/mv.test.js +14 -52
  26. package/commands/__tests__/open.test.js +13 -51
  27. package/commands/__tests__/project.test.js +44 -49
  28. package/commands/__tests__/remove.test.js +13 -51
  29. package/commands/__tests__/sandbox.test.js +14 -19
  30. package/commands/__tests__/secret.test.js +16 -21
  31. package/commands/__tests__/testAccount.test.js +16 -21
  32. package/commands/__tests__/theme.test.js +15 -20
  33. package/commands/account/__tests__/auth.test.js +11 -16
  34. package/commands/account/__tests__/clean.test.js +12 -17
  35. package/commands/account/__tests__/createOverride.test.js +10 -15
  36. package/commands/account/__tests__/info.test.js +11 -16
  37. package/commands/account/__tests__/list.test.js +11 -16
  38. package/commands/account/__tests__/remove.test.js +13 -18
  39. package/commands/account/__tests__/removeOverride.js +8 -13
  40. package/commands/account/__tests__/rename.test.js +15 -20
  41. package/commands/account/__tests__/use.test.js +10 -15
  42. package/commands/account/auth.d.ts +1 -1
  43. package/commands/account/auth.js +65 -67
  44. package/commands/account/clean.d.ts +1 -1
  45. package/commands/account/clean.js +55 -60
  46. package/commands/account/createOverride.d.ts +1 -1
  47. package/commands/account/createOverride.js +52 -57
  48. package/commands/account/info.d.ts +1 -1
  49. package/commands/account/info.js +33 -35
  50. package/commands/account/list.d.ts +1 -1
  51. package/commands/account/list.js +43 -45
  52. package/commands/account/remove.d.ts +1 -1
  53. package/commands/account/remove.js +37 -42
  54. package/commands/account/removeOverride.d.ts +1 -1
  55. package/commands/account/removeOverride.js +38 -43
  56. package/commands/account/rename.d.ts +1 -1
  57. package/commands/account/rename.js +18 -20
  58. package/commands/account/use.d.ts +1 -1
  59. package/commands/account/use.js +29 -31
  60. package/commands/account.d.ts +1 -1
  61. package/commands/account.js +23 -28
  62. package/commands/app/__tests__/migrate.test.js +29 -34
  63. package/commands/app/migrate.d.ts +2 -2
  64. package/commands/app/migrate.js +40 -43
  65. package/commands/app/secret/__tests__/add.test.js +6 -11
  66. package/commands/app/secret/__tests__/delete.test.js +6 -11
  67. package/commands/app/secret/__tests__/list.test.js +6 -11
  68. package/commands/app/secret/__tests__/update.test.js +6 -11
  69. package/commands/app/secret/add.d.ts +1 -1
  70. package/commands/app/secret/add.js +28 -30
  71. package/commands/app/secret/delete.d.ts +1 -1
  72. package/commands/app/secret/delete.js +34 -36
  73. package/commands/app/secret/list.d.ts +1 -1
  74. package/commands/app/secret/list.js +25 -27
  75. package/commands/app/secret/update.d.ts +1 -1
  76. package/commands/app/secret/update.js +32 -34
  77. package/commands/app/secret.d.ts +1 -1
  78. package/commands/app/secret.js +12 -17
  79. package/commands/app.d.ts +1 -1
  80. package/commands/app.js +6 -11
  81. package/commands/auth.d.ts +1 -1
  82. package/commands/auth.js +70 -72
  83. package/commands/cms/convertFields.d.ts +1 -1
  84. package/commands/cms/convertFields.js +34 -39
  85. package/commands/cms/getReactModule.d.ts +1 -1
  86. package/commands/cms/getReactModule.js +32 -37
  87. package/commands/cms/lighthouseScore.d.ts +1 -1
  88. package/commands/cms/lighthouseScore.js +67 -72
  89. package/commands/cms.d.ts +1 -1
  90. package/commands/cms.js +11 -16
  91. package/commands/completion.d.ts +1 -1
  92. package/commands/completion.js +10 -15
  93. package/commands/config/migrate.d.ts +1 -1
  94. package/commands/config/migrate.js +27 -32
  95. package/commands/config/set.d.ts +1 -1
  96. package/commands/config/set.js +23 -25
  97. package/commands/config.d.ts +1 -1
  98. package/commands/config.js +8 -13
  99. package/commands/create/api-sample.d.ts +1 -1
  100. package/commands/create/api-sample.js +28 -33
  101. package/commands/create/app.d.ts +1 -1
  102. package/commands/create/app.js +3 -5
  103. package/commands/create/function.d.ts +1 -1
  104. package/commands/create/function.js +9 -11
  105. package/commands/create/index.d.ts +1 -1
  106. package/commands/create/index.js +19 -24
  107. package/commands/create/module.d.ts +1 -1
  108. package/commands/create/module.js +12 -14
  109. package/commands/create/react-app.d.ts +1 -1
  110. package/commands/create/react-app.js +3 -5
  111. package/commands/create/template.d.ts +1 -1
  112. package/commands/create/template.js +12 -14
  113. package/commands/create/vue-app.d.ts +1 -1
  114. package/commands/create/vue-app.js +3 -5
  115. package/commands/create/webpack-serverless.d.ts +1 -1
  116. package/commands/create/webpack-serverless.js +3 -5
  117. package/commands/create/website-theme.d.ts +1 -1
  118. package/commands/create/website-theme.js +5 -7
  119. package/commands/create.d.ts +2 -2
  120. package/commands/create.js +30 -35
  121. package/commands/customObject/__tests__/create.test.js +13 -18
  122. package/commands/customObject/__tests__/schema.test.js +18 -23
  123. package/commands/customObject/create.d.ts +1 -1
  124. package/commands/customObject/create.js +28 -30
  125. package/commands/customObject/schema/__tests__/create.test.js +13 -18
  126. package/commands/customObject/schema/__tests__/delete.test.js +13 -18
  127. package/commands/customObject/schema/__tests__/fetch-all.test.js +13 -18
  128. package/commands/customObject/schema/__tests__/fetch.test.js +13 -18
  129. package/commands/customObject/schema/__tests__/list.test.js +13 -18
  130. package/commands/customObject/schema/__tests__/update.test.js +13 -18
  131. package/commands/customObject/schema/create.d.ts +1 -1
  132. package/commands/customObject/schema/create.js +28 -30
  133. package/commands/customObject/schema/delete.d.ts +1 -1
  134. package/commands/customObject/schema/delete.js +24 -26
  135. package/commands/customObject/schema/fetch-all.d.ts +1 -1
  136. package/commands/customObject/schema/fetch-all.js +22 -24
  137. package/commands/customObject/schema/fetch.d.ts +1 -1
  138. package/commands/customObject/schema/fetch.js +24 -26
  139. package/commands/customObject/schema/list.d.ts +1 -1
  140. package/commands/customObject/schema/list.js +13 -15
  141. package/commands/customObject/schema/update.d.ts +1 -1
  142. package/commands/customObject/schema/update.js +32 -34
  143. package/commands/customObject/schema.d.ts +1 -1
  144. package/commands/customObject/schema.js +17 -22
  145. package/commands/customObject.d.ts +1 -1
  146. package/commands/customObject.js +13 -18
  147. package/commands/doctor.d.ts +1 -1
  148. package/commands/doctor.js +28 -33
  149. package/commands/feedback.d.ts +1 -1
  150. package/commands/feedback.js +19 -24
  151. package/commands/fetch.d.ts +1 -1
  152. package/commands/fetch.js +28 -30
  153. package/commands/filemanager/__tests__/fetch.test.js +17 -22
  154. package/commands/filemanager/__tests__/upload.test.js +15 -20
  155. package/commands/filemanager/fetch.d.ts +1 -1
  156. package/commands/filemanager/fetch.js +23 -25
  157. package/commands/filemanager/upload.d.ts +1 -1
  158. package/commands/filemanager/upload.js +39 -44
  159. package/commands/filemanager.d.ts +1 -1
  160. package/commands/filemanager.js +8 -13
  161. package/commands/function/deploy.d.ts +1 -1
  162. package/commands/function/deploy.js +35 -40
  163. package/commands/function/list.d.ts +1 -1
  164. package/commands/function/list.js +24 -29
  165. package/commands/function/server.d.ts +1 -1
  166. package/commands/function/server.js +15 -17
  167. package/commands/function.d.ts +1 -1
  168. package/commands/function.js +12 -18
  169. package/commands/getStarted.d.ts +1 -1
  170. package/commands/getStarted.js +124 -130
  171. package/commands/hubdb/__tests__/clear.test.js +13 -18
  172. package/commands/hubdb/__tests__/create.test.js +13 -18
  173. package/commands/hubdb/__tests__/delete.test.js +13 -18
  174. package/commands/hubdb/__tests__/fetch.test.js +13 -18
  175. package/commands/hubdb/__tests__/list.test.js +23 -28
  176. package/commands/hubdb/clear.d.ts +1 -1
  177. package/commands/hubdb/clear.js +20 -22
  178. package/commands/hubdb/create.d.ts +1 -1
  179. package/commands/hubdb/create.js +30 -35
  180. package/commands/hubdb/delete.d.ts +1 -1
  181. package/commands/hubdb/delete.js +24 -26
  182. package/commands/hubdb/fetch.d.ts +1 -1
  183. package/commands/hubdb/fetch.js +17 -19
  184. package/commands/hubdb/list.d.ts +1 -1
  185. package/commands/hubdb/list.js +33 -35
  186. package/commands/hubdb.d.ts +1 -1
  187. package/commands/hubdb.js +18 -24
  188. package/commands/init.d.ts +1 -1
  189. package/commands/init.js +83 -88
  190. package/commands/lint.d.ts +1 -1
  191. package/commands/lint.js +24 -26
  192. package/commands/list.d.ts +1 -1
  193. package/commands/list.js +32 -37
  194. package/commands/logs.d.ts +1 -1
  195. package/commands/logs.js +35 -37
  196. package/commands/mcp/__tests__/setup.test.js +7 -12
  197. package/commands/mcp/__tests__/start.test.js +7 -12
  198. package/commands/mcp/setup.d.ts +1 -1
  199. package/commands/mcp/setup.js +17 -19
  200. package/commands/mcp/start.d.ts +1 -1
  201. package/commands/mcp/start.js +29 -34
  202. package/commands/mcp.d.ts +1 -1
  203. package/commands/mcp.js +7 -12
  204. package/commands/module/marketplace-validate.d.ts +1 -1
  205. package/commands/module/marketplace-validate.js +21 -26
  206. package/commands/module.d.ts +1 -1
  207. package/commands/module.js +7 -13
  208. package/commands/mv.d.ts +1 -1
  209. package/commands/mv.js +20 -22
  210. package/commands/open.d.ts +1 -1
  211. package/commands/open.js +19 -21
  212. package/commands/project/__tests__/add.test.js +10 -15
  213. package/commands/project/__tests__/create.test.js +14 -19
  214. package/commands/project/__tests__/deploy.test.js +93 -131
  215. package/commands/project/__tests__/devUnifiedFlow.test.js +135 -140
  216. package/commands/project/__tests__/download.test.js +14 -19
  217. package/commands/project/__tests__/installDeps.test.js +32 -70
  218. package/commands/project/__tests__/listBuilds.test.js +14 -19
  219. package/commands/project/__tests__/logs.test.js +56 -94
  220. package/commands/project/__tests__/migrate.test.js +25 -30
  221. package/commands/project/__tests__/migrateApp.test.js +17 -22
  222. package/commands/project/__tests__/open.test.js +16 -21
  223. package/commands/project/__tests__/profile.test.js +14 -19
  224. package/commands/project/__tests__/upload.test.js +18 -23
  225. package/commands/project/__tests__/watch.test.js +14 -19
  226. package/commands/project/add.d.ts +1 -1
  227. package/commands/project/add.js +34 -36
  228. package/commands/project/cloneApp.d.ts +1 -1
  229. package/commands/project/cloneApp.js +67 -72
  230. package/commands/project/create.d.ts +2 -2
  231. package/commands/project/create.js +62 -67
  232. package/commands/project/deploy.d.ts +1 -1
  233. package/commands/project/deploy.js +72 -77
  234. package/commands/project/dev/deprecatedFlow.d.ts +2 -2
  235. package/commands/project/dev/deprecatedFlow.js +52 -58
  236. package/commands/project/dev/index.d.ts +1 -1
  237. package/commands/project/dev/index.js +44 -47
  238. package/commands/project/dev/unifiedFlow.d.ts +3 -3
  239. package/commands/project/dev/unifiedFlow.js +62 -68
  240. package/commands/project/download.d.ts +1 -1
  241. package/commands/project/download.js +35 -40
  242. package/commands/project/installDeps.d.ts +1 -1
  243. package/commands/project/installDeps.js +29 -34
  244. package/commands/project/listBuilds.d.ts +1 -1
  245. package/commands/project/listBuilds.js +40 -45
  246. package/commands/project/logs.d.ts +1 -1
  247. package/commands/project/logs.js +52 -54
  248. package/commands/project/migrate.d.ts +1 -1
  249. package/commands/project/migrate.js +24 -26
  250. package/commands/project/migrateApp.d.ts +2 -2
  251. package/commands/project/migrateApp.js +18 -20
  252. package/commands/project/open.d.ts +1 -1
  253. package/commands/project/open.js +25 -30
  254. package/commands/project/profile/add.d.ts +1 -1
  255. package/commands/project/profile/add.js +68 -73
  256. package/commands/project/profile/delete.d.ts +1 -1
  257. package/commands/project/profile/delete.js +51 -56
  258. package/commands/project/profile.d.ts +1 -1
  259. package/commands/project/profile.js +9 -14
  260. package/commands/project/upload.d.ts +1 -1
  261. package/commands/project/upload.js +50 -55
  262. package/commands/project/validate.d.ts +1 -1
  263. package/commands/project/validate.js +35 -40
  264. package/commands/project/watch.d.ts +1 -1
  265. package/commands/project/watch.js +59 -61
  266. package/commands/project.d.ts +1 -1
  267. package/commands/project.js +38 -43
  268. package/commands/remove.d.ts +1 -1
  269. package/commands/remove.js +15 -17
  270. package/commands/sandbox/__tests__/create.test.js +15 -20
  271. package/commands/sandbox/__tests__/delete.test.js +15 -20
  272. package/commands/sandbox/create.d.ts +1 -1
  273. package/commands/sandbox/create.js +67 -69
  274. package/commands/sandbox/delete.d.ts +1 -1
  275. package/commands/sandbox/delete.js +94 -96
  276. package/commands/sandbox.d.ts +1 -1
  277. package/commands/sandbox.js +9 -14
  278. package/commands/secret/__tests__/addSecret.test.js +13 -18
  279. package/commands/secret/__tests__/deleteSecret.test.js +13 -18
  280. package/commands/secret/__tests__/listSecret.test.js +13 -18
  281. package/commands/secret/__tests__/updateSecret.test.js +13 -18
  282. package/commands/secret/addSecret.d.ts +1 -1
  283. package/commands/secret/addSecret.js +26 -28
  284. package/commands/secret/deleteSecret.d.ts +1 -1
  285. package/commands/secret/deleteSecret.js +27 -29
  286. package/commands/secret/listSecret.d.ts +1 -1
  287. package/commands/secret/listSecret.js +19 -21
  288. package/commands/secret/updateSecret.d.ts +1 -1
  289. package/commands/secret/updateSecret.js +25 -27
  290. package/commands/secret.d.ts +1 -1
  291. package/commands/secret.js +13 -18
  292. package/commands/testAccount/__tests__/create.test.js +17 -22
  293. package/commands/testAccount/__tests__/createConfig.test.js +6 -11
  294. package/commands/testAccount/__tests__/delete.test.js +15 -20
  295. package/commands/testAccount/create.d.ts +1 -1
  296. package/commands/testAccount/create.js +50 -55
  297. package/commands/testAccount/createConfig.d.ts +2 -2
  298. package/commands/testAccount/createConfig.js +36 -41
  299. package/commands/testAccount/delete.d.ts +1 -1
  300. package/commands/testAccount/delete.js +17 -19
  301. package/commands/testAccount.d.ts +1 -1
  302. package/commands/testAccount.js +10 -15
  303. package/commands/theme/__tests__/generate-selectors.test.js +7 -12
  304. package/commands/theme/__tests__/marketplace-validate.test.js +14 -19
  305. package/commands/theme/__tests__/preview.test.js +12 -17
  306. package/commands/theme/generate-selectors.d.ts +1 -1
  307. package/commands/theme/generate-selectors.js +23 -28
  308. package/commands/theme/marketplace-validate.d.ts +1 -1
  309. package/commands/theme/marketplace-validate.js +19 -24
  310. package/commands/theme/preview.d.ts +1 -1
  311. package/commands/theme/preview.js +60 -65
  312. package/commands/theme.d.ts +1 -1
  313. package/commands/theme.js +11 -16
  314. package/commands/upload.d.ts +1 -1
  315. package/commands/upload.js +77 -82
  316. package/commands/watch.d.ts +1 -1
  317. package/commands/watch.js +45 -51
  318. package/lang/en.d.ts +0 -1
  319. package/lang/en.js +369 -376
  320. package/lib/__tests__/accountTypes.test.js +20 -22
  321. package/lib/__tests__/buildAccount.test.js +26 -61
  322. package/lib/__tests__/commonOpts.test.js +20 -22
  323. package/lib/__tests__/dependencyManagement.test.js +46 -51
  324. package/lib/__tests__/developerTestAccounts.test.js +27 -62
  325. package/lib/__tests__/hasFeature.test.js +6 -8
  326. package/lib/__tests__/npm.test.js +15 -20
  327. package/lib/__tests__/oauth.test.js +23 -28
  328. package/lib/__tests__/parsing.test.js +18 -20
  329. package/lib/__tests__/polling.test.js +24 -26
  330. package/lib/__tests__/process.test.js +14 -19
  331. package/lib/__tests__/projectProfiles.test.js +34 -39
  332. package/lib/__tests__/sandboxSync.test.js +30 -35
  333. package/lib/__tests__/sandboxes.test.js +29 -31
  334. package/lib/__tests__/serverlessLogs.test.js +8 -13
  335. package/lib/__tests__/usageTracking.test.js +33 -34
  336. package/lib/__tests__/validation.test.js +18 -20
  337. package/lib/__tests__/yargsUtils.test.js +6 -41
  338. package/lib/accountTypes.js +24 -34
  339. package/lib/app/__tests__/migrate.test.js +94 -99
  340. package/lib/app/__tests__/migrate_legacy.test.js +29 -31
  341. package/lib/app/migrate.d.ts +3 -3
  342. package/lib/app/migrate.js +127 -145
  343. package/lib/app/migrate_legacy.d.ts +1 -1
  344. package/lib/app/migrate_legacy.js +72 -78
  345. package/lib/app/urls.js +5 -9
  346. package/lib/buildAccount.d.ts +1 -1
  347. package/lib/buildAccount.js +59 -67
  348. package/lib/commonOpts.d.ts +1 -1
  349. package/lib/commonOpts.js +42 -59
  350. package/lib/configMigrate.js +34 -38
  351. package/lib/configOptions.js +34 -40
  352. package/lib/constants.js +31 -34
  353. package/lib/customObject.js +2 -6
  354. package/lib/dependencyManagement.js +37 -45
  355. package/lib/developerTestAccounts.d.ts +1 -1
  356. package/lib/developerTestAccounts.js +34 -39
  357. package/lib/doctor/Diagnosis.d.ts +1 -1
  358. package/lib/doctor/Diagnosis.js +25 -29
  359. package/lib/doctor/DiagnosticInfoBuilder.d.ts +1 -1
  360. package/lib/doctor/DiagnosticInfoBuilder.js +30 -37
  361. package/lib/doctor/Doctor.d.ts +1 -1
  362. package/lib/doctor/Doctor.js +94 -101
  363. package/lib/doctor/__tests__/Diagnosis.test.js +9 -14
  364. package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.js +29 -34
  365. package/lib/doctor/__tests__/Doctor.test.js +24 -26
  366. package/lib/enums/exitCodes.js +1 -4
  367. package/lib/errorHandlers/index.js +32 -41
  368. package/lib/errorHandlers/suppressError.d.ts +1 -1
  369. package/lib/errorHandlers/suppressError.js +28 -31
  370. package/lib/filesystem.js +8 -15
  371. package/lib/generateSelectors.js +18 -29
  372. package/lib/hasFeature.d.ts +1 -1
  373. package/lib/hasFeature.js +3 -6
  374. package/lib/interpolation.js +11 -18
  375. package/lib/lang.d.ts +1 -1
  376. package/lib/lang.js +22 -27
  377. package/lib/links.js +16 -24
  378. package/lib/marketplaceValidate.js +29 -39
  379. package/lib/mcp/setup.js +69 -97
  380. package/lib/middleware/__test__/configMiddleware.test.js +20 -55
  381. package/lib/middleware/__test__/gitMiddleware.test.js +7 -42
  382. package/lib/middleware/__test__/notificationsMiddleware.test.js +2 -4
  383. package/lib/middleware/__test__/requestMiddleware.test.js +6 -11
  384. package/lib/middleware/__test__/utils.test.js +9 -11
  385. package/lib/middleware/__test__/yargsChecksMiddleware.test.js +9 -44
  386. package/lib/middleware/autoUpdateMiddleware.js +33 -40
  387. package/lib/middleware/configMiddleware.js +36 -42
  388. package/lib/middleware/fireAlarmMiddleware.js +12 -18
  389. package/lib/middleware/gitMiddleware.js +5 -8
  390. package/lib/middleware/notificationsMiddleware.js +16 -23
  391. package/lib/middleware/requestMiddleware.js +4 -10
  392. package/lib/middleware/utils.js +1 -4
  393. package/lib/middleware/yargsChecksMiddleware.js +10 -13
  394. package/lib/npm.js +14 -23
  395. package/lib/oauth.js +29 -35
  396. package/lib/parsing.js +3 -6
  397. package/lib/polling.js +11 -15
  398. package/lib/process.js +11 -19
  399. package/lib/projectProfiles.d.ts +2 -2
  400. package/lib/projectProfiles.js +32 -42
  401. package/lib/projects/ProjectLogsManager.js +18 -21
  402. package/lib/projects/__tests__/AppDevModeInterface.test.js +140 -145
  403. package/lib/projects/__tests__/LocalDevProcess.test.js +68 -73
  404. package/lib/projects/__tests__/LocalDevWebsocketServer.test.js +32 -37
  405. package/lib/projects/__tests__/ProjectLogsManager.test.js +56 -58
  406. package/lib/projects/__tests__/buildAndDeploy.test.js +7 -9
  407. package/lib/projects/__tests__/components.test.js +9 -14
  408. package/lib/projects/__tests__/projects.test.js +35 -40
  409. package/lib/projects/__tests__/structure.test.js +43 -81
  410. package/lib/projects/add/__tests__/legacyAddComponent.test.js +26 -28
  411. package/lib/projects/add/__tests__/v3AddComponent.test.js +25 -30
  412. package/lib/projects/add/legacyAddComponent.d.ts +1 -1
  413. package/lib/projects/add/legacyAddComponent.js +23 -29
  414. package/lib/projects/add/v3AddComponent.d.ts +1 -1
  415. package/lib/projects/add/v3AddComponent.js +35 -41
  416. package/lib/projects/buildAndDeploy.d.ts +1 -1
  417. package/lib/projects/buildAndDeploy.js +88 -97
  418. package/lib/projects/components.js +19 -25
  419. package/lib/projects/config.d.ts +1 -1
  420. package/lib/projects/config.js +32 -41
  421. package/lib/projects/create/__tests__/legacy.test.js +22 -57
  422. package/lib/projects/create/__tests__/v3.test.js +5 -7
  423. package/lib/projects/create/index.d.ts +3 -3
  424. package/lib/projects/create/index.js +19 -22
  425. package/lib/projects/create/legacy.d.ts +1 -1
  426. package/lib/projects/create/legacy.js +25 -31
  427. package/lib/projects/create/v3.d.ts +3 -3
  428. package/lib/projects/create/v3.js +49 -59
  429. package/lib/projects/ensureProjectExists.js +31 -37
  430. package/lib/projects/localDev/AppDevModeInterface.d.ts +3 -3
  431. package/lib/projects/localDev/AppDevModeInterface.js +58 -60
  432. package/lib/projects/localDev/DevServerManager.d.ts +1 -1
  433. package/lib/projects/localDev/DevServerManager.js +24 -26
  434. package/lib/projects/localDev/DevServerManagerV2.d.ts +2 -2
  435. package/lib/projects/localDev/DevServerManagerV2.js +17 -22
  436. package/lib/projects/localDev/LocalDevLogger.d.ts +1 -1
  437. package/lib/projects/localDev/LocalDevLogger.js +59 -64
  438. package/lib/projects/localDev/LocalDevManager.d.ts +1 -1
  439. package/lib/projects/localDev/LocalDevManager.js +106 -111
  440. package/lib/projects/localDev/LocalDevProcess.d.ts +4 -4
  441. package/lib/projects/localDev/LocalDevProcess.js +25 -30
  442. package/lib/projects/localDev/LocalDevState.d.ts +3 -3
  443. package/lib/projects/localDev/LocalDevState.js +3 -5
  444. package/lib/projects/localDev/LocalDevWatcher.d.ts +1 -1
  445. package/lib/projects/localDev/LocalDevWatcher.js +6 -11
  446. package/lib/projects/localDev/LocalDevWebsocketServer.d.ts +1 -1
  447. package/lib/projects/localDev/LocalDevWebsocketServer.js +25 -27
  448. package/lib/projects/localDev/helpers.d.ts +3 -3
  449. package/lib/projects/localDev/helpers.js +156 -174
  450. package/lib/projects/structure.d.ts +3 -3
  451. package/lib/projects/structure.js +32 -78
  452. package/lib/projects/ui.js +10 -13
  453. package/lib/projects/upload.d.ts +1 -1
  454. package/lib/projects/upload.js +55 -64
  455. package/lib/projects/urls.js +14 -24
  456. package/lib/projects/watch.d.ts +1 -1
  457. package/lib/projects/watch.js +48 -54
  458. package/lib/prompts/__tests__/downloadProjectPrompt.test.js +9 -11
  459. package/lib/prompts/__tests__/projectsLogsPrompt.test.js +11 -16
  460. package/lib/prompts/accountNamePrompt.d.ts +1 -1
  461. package/lib/prompts/accountNamePrompt.js +26 -31
  462. package/lib/prompts/accountsPrompt.js +12 -15
  463. package/lib/prompts/cmsFieldPrompt.js +13 -19
  464. package/lib/prompts/createApiSamplePrompt.d.ts +1 -1
  465. package/lib/prompts/createApiSamplePrompt.js +9 -12
  466. package/lib/prompts/createDeveloperTestAccountConfigPrompt.d.ts +1 -1
  467. package/lib/prompts/createDeveloperTestAccountConfigPrompt.js +16 -19
  468. package/lib/prompts/createFunctionPrompt.js +17 -20
  469. package/lib/prompts/createModulePrompt.js +12 -15
  470. package/lib/prompts/createTemplatePrompt.js +5 -8
  471. package/lib/prompts/downloadProjectPrompt.js +17 -20
  472. package/lib/prompts/installAppPrompt.js +19 -26
  473. package/lib/prompts/personalAccessKeyPrompt.d.ts +2 -2
  474. package/lib/prompts/personalAccessKeyPrompt.js +40 -47
  475. package/lib/prompts/previewPrompt.js +15 -22
  476. package/lib/prompts/projectAddPrompt.d.ts +1 -1
  477. package/lib/prompts/projectAddPrompt.js +14 -18
  478. package/lib/prompts/projectDevTargetAccountPrompt.d.ts +1 -1
  479. package/lib/prompts/projectDevTargetAccountPrompt.js +48 -54
  480. package/lib/prompts/projectNameAndDestPrompt.d.ts +1 -1
  481. package/lib/prompts/projectNameAndDestPrompt.js +22 -29
  482. package/lib/prompts/projectNamePrompt.js +11 -14
  483. package/lib/prompts/projectsLogsPrompt.js +5 -8
  484. package/lib/prompts/promptUtils.d.ts +1 -1
  485. package/lib/prompts/promptUtils.js +15 -22
  486. package/lib/prompts/sandboxesPrompt.d.ts +1 -1
  487. package/lib/prompts/sandboxesPrompt.js +26 -30
  488. package/lib/prompts/secretPrompt.js +10 -15
  489. package/lib/prompts/selectAppPrompt.js +11 -14
  490. package/lib/prompts/selectHubDBTablePrompt.js +24 -30
  491. package/lib/prompts/selectProjectTemplatePrompt.d.ts +1 -1
  492. package/lib/prompts/selectProjectTemplatePrompt.js +10 -13
  493. package/lib/prompts/selectPublicAppForMigrationPrompt.js +22 -25
  494. package/lib/prompts/setAsDefaultAccountPrompt.js +13 -16
  495. package/lib/prompts/uploadPrompt.js +11 -17
  496. package/lib/sandboxSync.d.ts +1 -1
  497. package/lib/sandboxSync.js +58 -65
  498. package/lib/sandboxes.d.ts +1 -1
  499. package/lib/sandboxes.js +68 -76
  500. package/lib/schema.js +12 -23
  501. package/lib/serverlessLogs.js +45 -52
  502. package/lib/testUtils.js +4 -8
  503. package/lib/ui/SpinniesManager.d.ts +1 -1
  504. package/lib/ui/SpinniesManager.js +29 -34
  505. package/lib/ui/boxen.js +11 -14
  506. package/lib/ui/git.js +14 -20
  507. package/lib/ui/index.js +55 -73
  508. package/lib/ui/logger.js +10 -13
  509. package/lib/ui/serverlessFunctionLogs.js +14 -20
  510. package/lib/ui/spinniesUtils.js +24 -39
  511. package/lib/ui/supportHyperlinks.js +3 -6
  512. package/lib/ui/supportsColor.js +11 -17
  513. package/lib/ui/table.js +6 -13
  514. package/lib/upload.js +15 -21
  515. package/lib/usageTracking.js +44 -50
  516. package/lib/utils/hasFlag.js +2 -8
  517. package/lib/validation.js +48 -87
  518. package/lib/yargsUtils.d.ts +1 -1
  519. package/lib/yargsUtils.js +13 -16
  520. package/mcp-server/server.js +6 -8
  521. package/mcp-server/tools/index.js +13 -16
  522. package/mcp-server/tools/project/AddFeatureToProject.d.ts +1 -1
  523. package/mcp-server/tools/project/AddFeatureToProject.js +33 -37
  524. package/mcp-server/tools/project/CreateProjectTool.d.ts +1 -1
  525. package/mcp-server/tools/project/CreateProjectTool.js +44 -48
  526. package/mcp-server/tools/project/DeployProject.d.ts +1 -1
  527. package/mcp-server/tools/project/DeployProject.js +16 -20
  528. package/mcp-server/tools/project/GuidedWalkthroughTool.d.ts +1 -1
  529. package/mcp-server/tools/project/GuidedWalkthroughTool.js +19 -23
  530. package/mcp-server/tools/project/UploadProjectTools.d.ts +1 -1
  531. package/mcp-server/tools/project/UploadProjectTools.js +10 -17
  532. package/mcp-server/tools/project/ValidateProjectTool.d.ts +1 -1
  533. package/mcp-server/tools/project/ValidateProjectTool.js +11 -15
  534. package/mcp-server/tools/project/__tests__/AddFeatureToProject.test.js +12 -14
  535. package/mcp-server/tools/project/__tests__/CreateProjectTool.test.js +13 -15
  536. package/mcp-server/tools/project/__tests__/DeployProject.test.js +6 -8
  537. package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.js +4 -6
  538. package/mcp-server/tools/project/__tests__/UploadProjectTools.test.js +4 -6
  539. package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.js +4 -6
  540. package/mcp-server/tools/project/constants.js +3 -9
  541. package/mcp-server/types.js +1 -5
  542. package/mcp-server/utils/__tests__/command.test.js +9 -11
  543. package/mcp-server/utils/__tests__/project.test.js +12 -17
  544. package/mcp-server/utils/command.d.ts +1 -1
  545. package/mcp-server/utils/command.js +4 -11
  546. package/mcp-server/utils/content.d.ts +1 -1
  547. package/mcp-server/utils/content.js +2 -6
  548. package/mcp-server/utils/project.js +8 -14
  549. package/package.json +15 -11
  550. package/types/LocalDev.d.ts +4 -4
  551. package/types/LocalDev.js +1 -2
  552. package/types/ProjectComponents.d.ts +2 -2
  553. package/types/ProjectComponents.js +1 -2
  554. package/types/Projects.d.ts +1 -1
  555. package/types/Projects.js +2 -5
  556. package/types/Prompts.js +1 -2
  557. package/types/Yargs.js +1 -2
  558. package/types/{Cms.d.ts → cms.d.ts} +1 -1
  559. package/types/cms.js +1 -0
  560. package/types/sandboxes.js +1 -0
  561. package/types/Cms.js +0 -2
  562. package/types/Sandboxes.js +0 -2
  563. /package/types/{Sandboxes.d.ts → sandboxes.d.ts} +0 -0
@@ -1,16 +1,11 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const config_1 = require("@hubspot/local-dev-lib/config");
7
- const config_2 = require("@hubspot/local-dev-lib/config");
8
- const logger_1 = require("@hubspot/local-dev-lib/logger");
9
- const logger_2 = require("../../ui/logger");
10
- const ui_1 = require("../../ui");
11
- const en_1 = require("../../../lang/en");
12
- const SpinniesManager_1 = __importDefault(require("../../ui/SpinniesManager"));
13
- const errorHandlers_1 = require("../../errorHandlers");
1
+ import { getAccountId } from '@hubspot/local-dev-lib/config';
2
+ import { getConfigDefaultAccount } from '@hubspot/local-dev-lib/config';
3
+ import { logger } from '@hubspot/local-dev-lib/logger';
4
+ import { uiLogger } from '../../ui/logger.js';
5
+ import { uiBetaTag, uiLine, uiAccountDescription, uiCommandReference, } from '../../ui/index.js';
6
+ import { lib } from '../../../lang/en.js';
7
+ import SpinniesManager from '../../ui/SpinniesManager.js';
8
+ import { logError } from '../../errorHandlers/index.js';
14
9
  class LocalDevLogger {
15
10
  state;
16
11
  mostRecentUploadWarning;
@@ -21,37 +16,37 @@ class LocalDevLogger {
21
16
  this.uploadWarnings = new Set();
22
17
  }
23
18
  logUploadInstructions(warning) {
24
- logger_2.uiLogger.log('');
25
- logger_2.uiLogger.warn(warning);
26
- logger_2.uiLogger.log('');
27
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.uploadWarning.instructionsHeader);
28
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.uploadWarning.stopDev);
19
+ uiLogger.log('');
20
+ uiLogger.warn(warning);
21
+ uiLogger.log('');
22
+ uiLogger.log(lib.LocalDevManager.uploadWarning.instructionsHeader);
23
+ uiLogger.log(lib.LocalDevManager.uploadWarning.stopDev);
29
24
  if (this.state.isGithubLinked) {
30
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.uploadWarning.pushToGithub);
25
+ uiLogger.log(lib.LocalDevManager.uploadWarning.pushToGithub);
31
26
  }
32
27
  else {
33
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.uploadWarning.runUpload(this.getUploadCommand()));
28
+ uiLogger.log(lib.LocalDevManager.uploadWarning.runUpload(this.getUploadCommand()));
34
29
  }
35
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.uploadWarning.restartDev);
30
+ uiLogger.log(lib.LocalDevManager.uploadWarning.restartDev);
36
31
  }
37
32
  handleError(e, langFunction) {
38
33
  if (this.state.debug) {
39
- logger_1.logger.error(e);
34
+ logger.error(e);
40
35
  }
41
- logger_2.uiLogger.error(langFunction(e instanceof Error ? e.message : ''));
36
+ uiLogger.error(langFunction(e instanceof Error ? e.message : ''));
42
37
  }
43
38
  getUploadCommand() {
44
- const currentDefaultAccount = (0, config_2.getConfigDefaultAccount)() || undefined;
39
+ const currentDefaultAccount = getConfigDefaultAccount() || undefined;
45
40
  return this.state.targetProjectAccountId !==
46
- (0, config_1.getAccountId)(currentDefaultAccount)
47
- ? (0, ui_1.uiCommandReference)(`hs project upload --account=${this.state.targetProjectAccountId}`)
48
- : (0, ui_1.uiCommandReference)('hs project upload');
41
+ getAccountId(currentDefaultAccount)
42
+ ? uiCommandReference(`hs project upload --account=${this.state.targetProjectAccountId}`)
43
+ : uiCommandReference('hs project upload');
49
44
  }
50
45
  uploadWarning() {
51
46
  // At the moment, there is only one additional warning. We may need to do this in a
52
47
  // more robust way in the future
53
48
  const additionalWarnings = Array.from(this.uploadWarnings).join('\n\n');
54
- const warning = `${en_1.lib.LocalDevManager.uploadWarning.defaultWarning} ${additionalWarnings}`;
49
+ const warning = `${lib.LocalDevManager.uploadWarning.defaultWarning} ${additionalWarnings}`;
55
50
  // Avoid logging the warning to the console if it is currently the most
56
51
  // recently logged warning. We do not want to spam the console with the same message.
57
52
  if (warning !== this.mostRecentUploadWarning) {
@@ -66,79 +61,79 @@ class LocalDevLogger {
66
61
  this.uploadWarnings.clear();
67
62
  }
68
63
  missingComponentsWarning(components) {
69
- const warning = en_1.lib.LocalDevManager.uploadWarning.missingComponents(components.join(', '));
64
+ const warning = lib.LocalDevManager.uploadWarning.missingComponents(components.join(', '));
70
65
  if (warning !== this.mostRecentUploadWarning) {
71
66
  this.logUploadInstructions(warning);
72
67
  this.mostRecentUploadWarning = warning;
73
68
  }
74
69
  }
75
70
  fileChangeError(e) {
76
- this.handleError(e, en_1.lib.LocalDevManager.devServer.fileChangeError);
71
+ this.handleError(e, lib.LocalDevManager.devServer.fileChangeError);
77
72
  }
78
73
  devServerSetupError(e) {
79
- this.handleError(e, en_1.lib.LocalDevManager.devServer.setupError);
74
+ this.handleError(e, lib.LocalDevManager.devServer.setupError);
80
75
  }
81
76
  devServerStartError(e) {
82
- this.handleError(e, en_1.lib.LocalDevManager.devServer.startError);
77
+ this.handleError(e, lib.LocalDevManager.devServer.startError);
83
78
  }
84
79
  devServerCleanupError(e) {
85
- this.handleError(e, en_1.lib.LocalDevManager.devServer.cleanupError);
80
+ this.handleError(e, lib.LocalDevManager.devServer.cleanupError);
86
81
  }
87
82
  noDeployedBuild() {
88
- logger_2.uiLogger.error(en_1.lib.LocalDevManager.noDeployedBuild(this.state.projectConfig.name, (0, ui_1.uiAccountDescription)(this.state.targetProjectAccountId), this.getUploadCommand()));
89
- logger_2.uiLogger.log('');
83
+ uiLogger.error(lib.LocalDevManager.noDeployedBuild(this.state.projectConfig.name, uiAccountDescription(this.state.targetProjectAccountId), this.getUploadCommand()));
84
+ uiLogger.log('');
90
85
  }
91
86
  resetSpinnies() {
92
- SpinniesManager_1.default.stopAll();
93
- SpinniesManager_1.default.init();
87
+ SpinniesManager.stopAll();
88
+ SpinniesManager.init();
94
89
  }
95
90
  startupMessage() {
96
91
  if (!this.state.debug) {
97
92
  console.clear();
98
93
  }
99
- (0, ui_1.uiBetaTag)(en_1.lib.LocalDevManager.betaMessage);
100
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.learnMoreLocalDevServer);
101
- logger_2.uiLogger.log('');
102
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.running(this.state.projectConfig.name, (0, ui_1.uiAccountDescription)(this.state.targetProjectAccountId)));
103
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.viewProjectLink(this.state.projectConfig.name, this.state.targetProjectAccountId));
104
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.viewLocalDevUILink(this.state.targetTestingAccountId));
105
- logger_2.uiLogger.log('');
106
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.quitHelper);
107
- (0, ui_1.uiLine)();
108
- logger_2.uiLogger.log('');
94
+ uiBetaTag(lib.LocalDevManager.betaMessage);
95
+ uiLogger.log(lib.LocalDevManager.learnMoreLocalDevServer);
96
+ uiLogger.log('');
97
+ uiLogger.log(lib.LocalDevManager.running(this.state.projectConfig.name, uiAccountDescription(this.state.targetProjectAccountId)));
98
+ uiLogger.log(lib.LocalDevManager.viewProjectLink(this.state.projectConfig.name, this.state.targetProjectAccountId));
99
+ uiLogger.log(lib.LocalDevManager.viewLocalDevUILink(this.state.targetTestingAccountId));
100
+ uiLogger.log('');
101
+ uiLogger.log(lib.LocalDevManager.quitHelper);
102
+ uiLine();
103
+ uiLogger.log('');
109
104
  }
110
105
  cleanupStart() {
111
- SpinniesManager_1.default.add('cleanupMessage', {
112
- text: en_1.lib.LocalDevManager.exitingStart,
106
+ SpinniesManager.add('cleanupMessage', {
107
+ text: lib.LocalDevManager.exitingStart,
113
108
  });
114
109
  }
115
110
  cleanupError() {
116
- SpinniesManager_1.default.fail('cleanupMessage', {
117
- text: en_1.lib.LocalDevManager.exitingFail,
111
+ SpinniesManager.fail('cleanupMessage', {
112
+ text: lib.LocalDevManager.exitingFail,
118
113
  });
119
114
  }
120
115
  cleanupSuccess() {
121
- SpinniesManager_1.default.succeed('cleanupMessage', {
122
- text: en_1.lib.LocalDevManager.exitingSucceed,
116
+ SpinniesManager.succeed('cleanupMessage', {
117
+ text: lib.LocalDevManager.exitingSucceed,
123
118
  });
124
119
  }
125
120
  uploadInitiated() {
126
- logger_2.uiLogger.log(en_1.lib.LocalDevProcess.uploadInitiated);
121
+ uiLogger.log(lib.LocalDevProcess.uploadInitiated);
127
122
  }
128
123
  projectConfigMismatch() {
129
- logger_2.uiLogger.log(en_1.lib.LocalDevProcess.projectConfigMismatch);
124
+ uiLogger.log(lib.LocalDevProcess.projectConfigMismatch);
130
125
  }
131
126
  uploadError(error) {
132
- logger_1.logger.log('');
133
- (0, errorHandlers_1.logError)(error);
134
- logger_2.uiLogger.log(en_1.lib.LocalDevProcess.uploadFailed);
135
- logger_1.logger.log('');
127
+ logger.log('');
128
+ logError(error);
129
+ uiLogger.log(lib.LocalDevProcess.uploadFailed);
130
+ logger.log('');
136
131
  }
137
132
  uploadSuccess() {
138
- logger_1.logger.log('');
139
- logger_2.uiLogger.log(en_1.lib.LocalDevProcess.uploadSuccess);
140
- (0, ui_1.uiLine)();
141
- logger_1.logger.log('');
133
+ logger.log('');
134
+ uiLogger.log(lib.LocalDevProcess.uploadSuccess);
135
+ uiLine();
136
+ logger.log('');
142
137
  }
143
138
  monitorConsoleOutput() {
144
139
  const originalStdoutWrite = process.stdout.write.bind(process.stdout);
@@ -156,4 +151,4 @@ class LocalDevLogger {
156
151
  process.stdout.write = customStdoutWrite;
157
152
  }
158
153
  }
159
- exports.default = LocalDevLogger;
154
+ export default LocalDevLogger;
@@ -2,7 +2,7 @@ import { FSWatcher } from 'chokidar';
2
2
  import { Build } from '@hubspot/local-dev-lib/types/Build';
3
3
  import { PublicApp } from '@hubspot/local-dev-lib/types/Apps';
4
4
  import { Environment } from '@hubspot/local-dev-lib/types/Config';
5
- import { Component, ProjectConfig } from '../../../types/Projects';
5
+ import { Component, ProjectConfig } from '../../../types/Projects.js';
6
6
  type LocalDevManagerConstructorOptions = {
7
7
  targetAccountId: number;
8
8
  parentAccountId: number;
@@ -1,30 +1,25 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const path_1 = __importDefault(require("path"));
7
- const chokidar_1 = __importDefault(require("chokidar"));
8
- const chalk_1 = __importDefault(require("chalk"));
9
- const localDevAuth_1 = require("@hubspot/local-dev-lib/api/localDevAuth");
10
- const appsDev_1 = require("@hubspot/local-dev-lib/api/appsDev");
11
- const config_1 = require("@hubspot/local-dev-lib/config");
12
- const logger_1 = require("@hubspot/local-dev-lib/logger");
13
- const constants_1 = require("../../constants");
14
- const SpinniesManager_1 = __importDefault(require("../../ui/SpinniesManager"));
15
- const DevServerManager_1 = __importDefault(require("./DevServerManager"));
16
- const exitCodes_1 = require("../../enums/exitCodes");
17
- const helpers_1 = require("./helpers");
18
- const structure_1 = require("../../projects/structure");
19
- const Projects_1 = require("../../../types/Projects");
20
- const ui_1 = require("../../ui");
21
- const index_1 = require("../../errorHandlers/index");
22
- const installAppPrompt_1 = require("../../prompts/installAppPrompt");
23
- const promptUtils_1 = require("../../prompts/promptUtils");
24
- const process_1 = require("../../process");
25
- const en_1 = require("../../../lang/en");
26
- const logger_2 = require("../../ui/logger");
27
- const urls_1 = require("../../app/urls");
1
+ import path from 'path';
2
+ import chokidar from 'chokidar';
3
+ import chalk from 'chalk';
4
+ import { fetchAppInstallationData } from '@hubspot/local-dev-lib/api/localDevAuth';
5
+ import { fetchPublicAppsForPortal, fetchPublicAppProductionInstallCounts, } from '@hubspot/local-dev-lib/api/appsDev';
6
+ import { getAccountId, getConfigDefaultAccount, } from '@hubspot/local-dev-lib/config';
7
+ import { logger } from '@hubspot/local-dev-lib/logger';
8
+ import { PROJECT_CONFIG_FILE } from '../../constants.js';
9
+ import SpinniesManager from '../../ui/SpinniesManager.js';
10
+ import DevServerManager from './DevServerManager.js';
11
+ import { EXIT_CODES } from '../../enums/exitCodes.js';
12
+ import { getAccountHomeUrl } from './helpers.js';
13
+ import { componentIsApp, componentIsPublicApp, CONFIG_FILES, getAppCardConfigs, getComponentUid, } from '../../projects/structure.js';
14
+ import { ComponentTypes, } from '../../../types/Projects.js';
15
+ import { UI_COLORS, uiCommandReference, uiAccountDescription, uiBetaTag, uiLink, uiLine, } from '../../ui/index.js';
16
+ import { logError } from '../../errorHandlers/index.js';
17
+ import { installAppBrowserPrompt } from '../../prompts/installAppPrompt.js';
18
+ import { confirmPrompt } from '../../prompts/promptUtils.js';
19
+ import { handleKeypress } from '../../process.js';
20
+ import { lib } from '../../../lang/en.js';
21
+ import { uiLogger } from '../../ui/logger.js';
22
+ import { getOauthAppInstallUrl } from '../../app/urls.js';
28
23
  const WATCH_EVENTS = {
29
24
  add: 'add',
30
25
  change: 'change',
@@ -67,29 +62,29 @@ class LocalDevManager {
67
62
  this.env = options.env;
68
63
  this.publicAppActiveInstalls = null;
69
64
  this.mostRecentUploadWarning = null;
70
- this.projectSourceDir = path_1.default.join(this.projectDir, this.projectConfig.srcDir);
65
+ this.projectSourceDir = path.join(this.projectDir, this.projectConfig.srcDir);
71
66
  if (!this.targetAccountId || !this.projectConfig || !this.projectDir) {
72
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.failedToInitialize);
73
- process.exit(exitCodes_1.EXIT_CODES.ERROR);
67
+ uiLogger.log(lib.LocalDevManager.failedToInitialize);
68
+ process.exit(EXIT_CODES.ERROR);
74
69
  }
75
70
  }
76
71
  async setActiveApp(appUid) {
77
72
  if (!appUid) {
78
- logger_2.uiLogger.error(en_1.lib.LocalDevManager.missingUid);
79
- process.exit(exitCodes_1.EXIT_CODES.ERROR);
73
+ uiLogger.error(lib.LocalDevManager.missingUid);
74
+ process.exit(EXIT_CODES.ERROR);
80
75
  }
81
76
  this.activeApp =
82
77
  this.runnableComponents.find(component => {
83
- return (0, structure_1.getComponentUid)(component) === appUid;
78
+ return getComponentUid(component) === appUid;
84
79
  }) || null;
85
- if ((0, structure_1.componentIsPublicApp)(this.activeApp)) {
80
+ if (componentIsPublicApp(this.activeApp)) {
86
81
  try {
87
82
  await this.setActivePublicAppData();
88
83
  await this.checkActivePublicAppInstalls();
89
84
  await this.checkPublicAppInstallation();
90
85
  }
91
86
  catch (e) {
92
- (0, index_1.logError)(e);
87
+ logError(e);
93
88
  }
94
89
  }
95
90
  }
@@ -97,12 +92,12 @@ class LocalDevManager {
97
92
  if (!this.activeApp) {
98
93
  return;
99
94
  }
100
- const { data: { results: portalPublicApps }, } = await (0, appsDev_1.fetchPublicAppsForPortal)(this.targetProjectAccountId);
101
- const activePublicAppData = portalPublicApps.find(({ sourceId }) => sourceId === (0, structure_1.getComponentUid)(this.activeApp));
95
+ const { data: { results: portalPublicApps }, } = await fetchPublicAppsForPortal(this.targetProjectAccountId);
96
+ const activePublicAppData = portalPublicApps.find(({ sourceId }) => sourceId === getComponentUid(this.activeApp));
102
97
  if (!activePublicAppData) {
103
98
  return;
104
99
  }
105
- const { data: { uniquePortalInstallCount }, } = await (0, appsDev_1.fetchPublicAppProductionInstallCounts)(activePublicAppData.id, this.targetProjectAccountId);
100
+ const { data: { uniquePortalInstallCount }, } = await fetchPublicAppProductionInstallCounts(activePublicAppData.id, this.targetProjectAccountId);
106
101
  this.activePublicAppData = activePublicAppData;
107
102
  this.publicAppActiveInstalls = uniquePortalInstallCount;
108
103
  }
@@ -112,43 +107,43 @@ class LocalDevManager {
112
107
  this.publicAppActiveInstalls < 1) {
113
108
  return;
114
109
  }
115
- (0, ui_1.uiLine)();
116
- logger_2.uiLogger.warn(en_1.lib.LocalDevManager.activeInstallWarning.installCount(this.activePublicAppData.name, this.publicAppActiveInstalls));
117
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.activeInstallWarning.explanation);
118
- (0, ui_1.uiLine)();
119
- const proceed = await (0, promptUtils_1.confirmPrompt)(en_1.lib.LocalDevManager.activeInstallWarning.confirmationPrompt, { defaultAnswer: false });
110
+ uiLine();
111
+ uiLogger.warn(lib.LocalDevManager.activeInstallWarning.installCount(this.activePublicAppData.name, this.publicAppActiveInstalls));
112
+ uiLogger.log(lib.LocalDevManager.activeInstallWarning.explanation);
113
+ uiLine();
114
+ const proceed = await confirmPrompt(lib.LocalDevManager.activeInstallWarning.confirmationPrompt, { defaultAnswer: false });
120
115
  if (!proceed) {
121
- process.exit(exitCodes_1.EXIT_CODES.SUCCESS);
116
+ process.exit(EXIT_CODES.SUCCESS);
122
117
  }
123
118
  }
124
119
  async start() {
125
- SpinniesManager_1.default.stopAll();
126
- SpinniesManager_1.default.init();
120
+ SpinniesManager.stopAll();
121
+ SpinniesManager.init();
127
122
  // Local dev currently relies on the existence of a deployed build in the target account
128
123
  if (!this.deployedBuild) {
129
- logger_2.uiLogger.error(en_1.lib.LocalDevManager.noDeployedBuild(this.projectConfig.name, (0, ui_1.uiAccountDescription)(this.targetProjectAccountId), this.getUploadCommand()));
130
- logger_2.uiLogger.log('');
131
- process.exit(exitCodes_1.EXIT_CODES.SUCCESS);
124
+ uiLogger.error(lib.LocalDevManager.noDeployedBuild(this.projectConfig.name, uiAccountDescription(this.targetProjectAccountId), this.getUploadCommand()));
125
+ uiLogger.log('');
126
+ process.exit(EXIT_CODES.SUCCESS);
132
127
  }
133
128
  const setupSucceeded = await this.devServerSetup();
134
129
  if (!setupSucceeded) {
135
- process.exit(exitCodes_1.EXIT_CODES.ERROR);
130
+ process.exit(EXIT_CODES.ERROR);
136
131
  }
137
132
  else if (!this.debug) {
138
133
  console.clear();
139
134
  }
140
- (0, ui_1.uiBetaTag)(en_1.lib.LocalDevManager.betaMessage);
141
- logger_2.uiLogger.log((0, ui_1.uiLink)(en_1.lib.LocalDevManager.learnMoreLocalDevServer, 'https://developers.hubspot.com/docs/platform/project-cli-commands#start-a-local-development-server'));
142
- logger_2.uiLogger.log('');
143
- logger_2.uiLogger.log(chalk_1.default.hex(ui_1.UI_COLORS.SORBET)(en_1.lib.LocalDevManager.running(this.projectConfig.name, (0, ui_1.uiAccountDescription)(this.targetAccountId))));
144
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.viewProjectLink(this.projectConfig.name, this.targetProjectAccountId));
145
- if (this.activeApp?.type === Projects_1.ComponentTypes.PublicApp) {
146
- logger_2.uiLogger.log((0, ui_1.uiLink)(en_1.lib.LocalDevManager.viewTestAccountLink, (0, helpers_1.getAccountHomeUrl)(this.targetAccountId)));
135
+ uiBetaTag(lib.LocalDevManager.betaMessage);
136
+ uiLogger.log(uiLink(lib.LocalDevManager.learnMoreLocalDevServer, 'https://developers.hubspot.com/docs/platform/project-cli-commands#start-a-local-development-server'));
137
+ uiLogger.log('');
138
+ uiLogger.log(chalk.hex(UI_COLORS.SORBET)(lib.LocalDevManager.running(this.projectConfig.name, uiAccountDescription(this.targetAccountId))));
139
+ uiLogger.log(lib.LocalDevManager.viewProjectLink(this.projectConfig.name, this.targetProjectAccountId));
140
+ if (this.activeApp?.type === ComponentTypes.PublicApp) {
141
+ uiLogger.log(uiLink(lib.LocalDevManager.viewTestAccountLink, getAccountHomeUrl(this.targetAccountId)));
147
142
  }
148
- logger_2.uiLogger.log('');
149
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.quitHelper);
150
- (0, ui_1.uiLine)();
151
- logger_2.uiLogger.log('');
143
+ uiLogger.log('');
144
+ uiLogger.log(lib.LocalDevManager.quitHelper);
145
+ uiLine();
146
+ uiLogger.log('');
152
147
  await this.devServerStart();
153
148
  // Initialize project file watcher to detect configuration file changes
154
149
  this.startWatching();
@@ -160,56 +155,56 @@ class LocalDevManager {
160
155
  }
161
156
  async stop(showProgress = true) {
162
157
  if (showProgress) {
163
- SpinniesManager_1.default.add('cleanupMessage', {
164
- text: en_1.lib.LocalDevManager.exitingStart,
158
+ SpinniesManager.add('cleanupMessage', {
159
+ text: lib.LocalDevManager.exitingStart,
165
160
  });
166
161
  }
167
162
  await this.stopWatching();
168
163
  const cleanupSucceeded = await this.devServerCleanup();
169
164
  if (!cleanupSucceeded) {
170
165
  if (showProgress) {
171
- SpinniesManager_1.default.fail('cleanupMessage', {
172
- text: en_1.lib.LocalDevManager.exitingFail,
166
+ SpinniesManager.fail('cleanupMessage', {
167
+ text: lib.LocalDevManager.exitingFail,
173
168
  });
174
169
  }
175
- process.exit(exitCodes_1.EXIT_CODES.ERROR);
170
+ process.exit(EXIT_CODES.ERROR);
176
171
  }
177
172
  if (showProgress) {
178
- SpinniesManager_1.default.succeed('cleanupMessage', {
179
- text: en_1.lib.LocalDevManager.exitingSucceed,
173
+ SpinniesManager.succeed('cleanupMessage', {
174
+ text: lib.LocalDevManager.exitingSucceed,
180
175
  });
181
176
  }
182
- process.exit(exitCodes_1.EXIT_CODES.SUCCESS);
177
+ process.exit(EXIT_CODES.SUCCESS);
183
178
  }
184
179
  async checkPublicAppInstallation() {
185
- if (!(0, structure_1.componentIsPublicApp)(this.activeApp) || !this.activePublicAppData) {
180
+ if (!componentIsPublicApp(this.activeApp) || !this.activePublicAppData) {
186
181
  return;
187
182
  }
188
- const { data: { isInstalledWithScopeGroups, previouslyAuthorizedScopeGroups }, } = await (0, localDevAuth_1.fetchAppInstallationData)(this.targetAccountId, this.projectId, this.activeApp.config.uid, this.activeApp.config.auth.requiredScopes, this.activeApp.config.auth.optionalScopes);
183
+ const { data: { isInstalledWithScopeGroups, previouslyAuthorizedScopeGroups }, } = await fetchAppInstallationData(this.targetAccountId, this.projectId, this.activeApp.config.uid, this.activeApp.config.auth.requiredScopes, this.activeApp.config.auth.optionalScopes);
189
184
  const isReinstall = previouslyAuthorizedScopeGroups.length > 0;
190
185
  if (!isInstalledWithScopeGroups) {
191
- const installUrl = (0, urls_1.getOauthAppInstallUrl)({
186
+ const installUrl = getOauthAppInstallUrl({
192
187
  targetAccountId: this.targetAccountId,
193
188
  env: this.env,
194
189
  clientId: this.activePublicAppData.clientId,
195
190
  scopes: this.activeApp.config.auth.requiredScopes,
196
191
  redirectUrls: this.activeApp.config.auth.redirectUrls,
197
192
  });
198
- await (0, installAppPrompt_1.installAppBrowserPrompt)(installUrl, isReinstall);
193
+ await installAppBrowserPrompt(installUrl, isReinstall);
199
194
  }
200
195
  }
201
196
  updateKeypressListeners() {
202
- (0, process_1.handleKeypress)(async (key) => {
197
+ handleKeypress(async (key) => {
203
198
  if ((key.ctrl && key.name === 'c') || key.name === 'q') {
204
199
  this.stop();
205
200
  }
206
201
  });
207
202
  }
208
203
  getUploadCommand() {
209
- const currentDefaultAccount = (0, config_1.getConfigDefaultAccount)() || undefined;
210
- return this.targetProjectAccountId !== (0, config_1.getAccountId)(currentDefaultAccount)
211
- ? (0, ui_1.uiCommandReference)(`hs project upload --account=${this.targetProjectAccountId}`)
212
- : (0, ui_1.uiCommandReference)('hs project upload');
204
+ const currentDefaultAccount = getConfigDefaultAccount() || undefined;
205
+ return this.targetProjectAccountId !== getAccountId(currentDefaultAccount)
206
+ ? uiCommandReference(`hs project upload --account=${this.targetProjectAccountId}`)
207
+ : uiCommandReference('hs project upload');
213
208
  }
214
209
  logUploadWarning(reason) {
215
210
  let warning;
@@ -218,25 +213,25 @@ class LocalDevManager {
218
213
  }
219
214
  else {
220
215
  warning =
221
- (0, structure_1.componentIsPublicApp)(this.activeApp) &&
216
+ componentIsPublicApp(this.activeApp) &&
222
217
  this.publicAppActiveInstalls &&
223
218
  this.publicAppActiveInstalls > 0
224
- ? en_1.lib.LocalDevManager.uploadWarning.defaultPublicAppWarning(this.publicAppActiveInstalls, this.publicAppActiveInstalls === 1 ? 'install' : 'installs')
225
- : en_1.lib.LocalDevManager.uploadWarning.defaultWarning;
219
+ ? lib.LocalDevManager.uploadWarning.defaultPublicAppWarning(this.publicAppActiveInstalls, this.publicAppActiveInstalls === 1 ? 'install' : 'installs')
220
+ : lib.LocalDevManager.uploadWarning.defaultWarning;
226
221
  }
227
222
  // Avoid logging the warning to the console if it is currently the most
228
223
  // recently logged warning. We do not want to spam the console with the same message.
229
224
  if (!this.uploadWarnings[warning]) {
230
- logger_2.uiLogger.log('');
231
- logger_2.uiLogger.warn(en_1.lib.LocalDevManager.uploadWarning.header(warning));
232
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.uploadWarning.stopDev);
225
+ uiLogger.log('');
226
+ uiLogger.warn(lib.LocalDevManager.uploadWarning.header(warning));
227
+ uiLogger.log(lib.LocalDevManager.uploadWarning.stopDev);
233
228
  if (this.isGithubLinked) {
234
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.uploadWarning.pushToGithub);
229
+ uiLogger.log(lib.LocalDevManager.uploadWarning.pushToGithub);
235
230
  }
236
231
  else {
237
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.uploadWarning.runUpload(this.getUploadCommand()));
232
+ uiLogger.log(lib.LocalDevManager.uploadWarning.runUpload(this.getUploadCommand()));
238
233
  }
239
- logger_2.uiLogger.log(en_1.lib.LocalDevManager.uploadWarning.restartDev);
234
+ uiLogger.log(lib.LocalDevManager.uploadWarning.restartDev);
240
235
  this.mostRecentUploadWarning = warning;
241
236
  this.uploadWarnings[warning] = true;
242
237
  }
@@ -261,37 +256,37 @@ class LocalDevManager {
261
256
  const deployedComponentNames = this.deployedBuild.subbuildStatuses.map(subbuildStatus => subbuildStatus.buildName);
262
257
  const missingComponents = [];
263
258
  this.runnableComponents
264
- .filter(structure_1.componentIsApp)
259
+ .filter(componentIsApp)
265
260
  .forEach(({ type, config, path }) => {
266
- if (Object.values(Projects_1.ComponentTypes).includes(type)) {
267
- const cardConfigs = (0, structure_1.getAppCardConfigs)(config, path);
261
+ if (Object.values(ComponentTypes).includes(type)) {
262
+ const cardConfigs = getAppCardConfigs(config, path);
268
263
  if (!deployedComponentNames.includes(config.name)) {
269
- missingComponents.push(`${en_1.lib.LocalDevManager.uploadWarning.appLabel} ${config.name}`);
264
+ missingComponents.push(`${lib.LocalDevManager.uploadWarning.appLabel} ${config.name}`);
270
265
  }
271
266
  cardConfigs.forEach(cardConfig => {
272
267
  if (cardConfig.data &&
273
268
  cardConfig.data.title &&
274
269
  !deployedComponentNames.includes(cardConfig.data.title)) {
275
- missingComponents.push(`${en_1.lib.LocalDevManager.uploadWarning.uiExtensionLabel} ${cardConfig.data.title}`);
270
+ missingComponents.push(`${lib.LocalDevManager.uploadWarning.uiExtensionLabel} ${cardConfig.data.title}`);
276
271
  }
277
272
  });
278
273
  }
279
274
  });
280
275
  if (missingComponents.length) {
281
- this.logUploadWarning(en_1.lib.LocalDevManager.uploadWarning.missingComponents(missingComponents.join(', ')));
276
+ this.logUploadWarning(lib.LocalDevManager.uploadWarning.missingComponents(missingComponents.join(', ')));
282
277
  }
283
278
  }
284
279
  startWatching() {
285
- this.watcher = chokidar_1.default.watch(this.projectDir, {
280
+ this.watcher = chokidar.watch(this.projectDir, {
286
281
  ignoreInitial: true,
287
282
  });
288
283
  const configPaths = this.runnableComponents
289
- .filter(({ type }) => Object.values(Projects_1.ComponentTypes).includes(type))
284
+ .filter(({ type }) => Object.values(ComponentTypes).includes(type))
290
285
  .map(component => {
291
- const appConfigPath = path_1.default.join(component.path, structure_1.CONFIG_FILES[component.type]);
286
+ const appConfigPath = path.join(component.path, CONFIG_FILES[component.type]);
292
287
  return appConfigPath;
293
288
  });
294
- const projectConfigPath = path_1.default.join(this.projectDir, constants_1.PROJECT_CONFIG_FILE);
289
+ const projectConfigPath = path.join(this.projectDir, PROJECT_CONFIG_FILE);
295
290
  configPaths.push(projectConfigPath);
296
291
  this.watcher.on('add', filePath => {
297
292
  this.handleWatchEvent(filePath, WATCH_EVENTS.add, configPaths);
@@ -319,7 +314,7 @@ class LocalDevManager {
319
314
  }
320
315
  async devServerSetup() {
321
316
  try {
322
- await DevServerManager_1.default.setup({
317
+ await DevServerManager.setup({
323
318
  components: this.runnableComponents,
324
319
  onUploadRequired: this.logUploadWarning.bind(this),
325
320
  accountId: this.targetAccountId,
@@ -329,50 +324,50 @@ class LocalDevManager {
329
324
  }
330
325
  catch (e) {
331
326
  if (this.debug) {
332
- logger_1.logger.error(e);
327
+ logger.error(e);
333
328
  }
334
- logger_2.uiLogger.error(en_1.lib.LocalDevManager.devServer.setupError(e instanceof Error ? e.message : ''));
329
+ uiLogger.error(lib.LocalDevManager.devServer.setupError(e instanceof Error ? e.message : ''));
335
330
  return false;
336
331
  }
337
332
  }
338
333
  async devServerStart() {
339
334
  try {
340
- await DevServerManager_1.default.start({
335
+ await DevServerManager.start({
341
336
  accountId: this.targetAccountId,
342
337
  projectConfig: this.projectConfig,
343
338
  });
344
339
  }
345
340
  catch (e) {
346
341
  if (this.debug) {
347
- logger_1.logger.error(e);
342
+ logger.error(e);
348
343
  }
349
- logger_2.uiLogger.error(en_1.lib.LocalDevManager.devServer.startError(e instanceof Error ? e.message : ''));
350
- process.exit(exitCodes_1.EXIT_CODES.ERROR);
344
+ uiLogger.error(lib.LocalDevManager.devServer.startError(e instanceof Error ? e.message : ''));
345
+ process.exit(EXIT_CODES.ERROR);
351
346
  }
352
347
  }
353
348
  devServerFileChange(filePath, event) {
354
349
  try {
355
- DevServerManager_1.default.fileChange({ filePath, event });
350
+ DevServerManager.fileChange({ filePath, event });
356
351
  }
357
352
  catch (e) {
358
353
  if (this.debug) {
359
- logger_1.logger.error(e);
354
+ logger.error(e);
360
355
  }
361
- logger_2.uiLogger.error(en_1.lib.LocalDevManager.devServer.fileChangeError(e instanceof Error ? e.message : ''));
356
+ uiLogger.error(lib.LocalDevManager.devServer.fileChangeError(e instanceof Error ? e.message : ''));
362
357
  }
363
358
  }
364
359
  async devServerCleanup() {
365
360
  try {
366
- await DevServerManager_1.default.cleanup();
361
+ await DevServerManager.cleanup();
367
362
  return true;
368
363
  }
369
364
  catch (e) {
370
365
  if (this.debug) {
371
- logger_1.logger.error(e);
366
+ logger.error(e);
372
367
  }
373
- logger_2.uiLogger.error(en_1.lib.LocalDevManager.devServer.cleanupError(e instanceof Error ? e.message : ''));
368
+ uiLogger.error(lib.LocalDevManager.devServer.cleanupError(e instanceof Error ? e.message : ''));
374
369
  return false;
375
370
  }
376
371
  }
377
372
  }
378
- exports.default = LocalDevManager;
373
+ export default LocalDevManager;
@@ -1,7 +1,7 @@
1
- import { IntermediateRepresentationNodeLocalDev } from '@hubspot/project-parsing-lib/src/lib/types';
2
- import LocalDevState from './LocalDevState';
3
- import LocalDevLogger from './LocalDevLogger';
4
- import { LocalDevStateConstructorOptions, LocalDevStateListener, LocalDevServerMessage } from '../../../types/LocalDev';
1
+ import { IntermediateRepresentationNodeLocalDev } from '@hubspot/project-parsing-lib/src/lib/types.js';
2
+ import LocalDevState from './LocalDevState.js';
3
+ import LocalDevLogger from './LocalDevLogger.js';
4
+ import { LocalDevStateConstructorOptions, LocalDevStateListener, LocalDevServerMessage } from '../../../types/LocalDev.js';
5
5
  declare class LocalDevProcess {
6
6
  private state;
7
7
  private _logger;