@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
package/lib/sandboxes.js CHANGED
@@ -1,45 +1,37 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SANDBOX_API_TYPE_MAP = exports.SANDBOX_TYPE_MAP = exports.SYNC_TYPES = void 0;
4
- exports.getSandboxTypeAsString = getSandboxTypeAsString;
5
- exports.getHasSandboxesByType = getHasSandboxesByType;
6
- exports.getAvailableSyncTypes = getAvailableSyncTypes;
7
- exports.validateSandboxUsageLimits = validateSandboxUsageLimits;
8
- exports.handleSandboxCreateError = handleSandboxCreateError;
9
- const logger_1 = require("@hubspot/local-dev-lib/logger");
10
- const sandboxHubs_1 = require("@hubspot/local-dev-lib/api/sandboxHubs");
11
- const sandboxSync_1 = require("@hubspot/local-dev-lib/api/sandboxSync");
12
- const config_1 = require("@hubspot/local-dev-lib/config");
13
- const urls_1 = require("@hubspot/local-dev-lib/urls");
14
- const config_2 = require("@hubspot/local-dev-lib/constants/config");
15
- const getAccountIdentifier_1 = require("@hubspot/local-dev-lib/config/getAccountIdentifier");
16
- const index_1 = require("@hubspot/local-dev-lib/errors/index");
17
- const lang_1 = require("./lang");
18
- const ui_1 = require("./ui");
19
- const index_2 = require("./errorHandlers/index");
20
- exports.SYNC_TYPES = {
1
+ import { logger } from '@hubspot/local-dev-lib/logger';
2
+ import { getSandboxUsageLimits } from '@hubspot/local-dev-lib/api/sandboxHubs';
3
+ import { fetchTypes } from '@hubspot/local-dev-lib/api/sandboxSync';
4
+ import { getAccountId, getConfigAccounts } from '@hubspot/local-dev-lib/config';
5
+ import { getHubSpotWebsiteOrigin } from '@hubspot/local-dev-lib/urls';
6
+ import { HUBSPOT_ACCOUNT_TYPES } from '@hubspot/local-dev-lib/constants/config';
7
+ import { getAccountIdentifier } from '@hubspot/local-dev-lib/config/getAccountIdentifier';
8
+ import { isMissingScopeError, isSpecifiedError, } from '@hubspot/local-dev-lib/errors/index';
9
+ import { i18n } from './lang.js';
10
+ import { uiAccountDescription } from './ui/index.js';
11
+ import { logError } from './errorHandlers/index.js';
12
+ export const SYNC_TYPES = {
21
13
  OBJECT_RECORDS: 'object-records',
22
14
  };
23
- exports.SANDBOX_TYPE_MAP = {
24
- dev: config_2.HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX,
25
- developer: config_2.HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX,
26
- development: config_2.HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX,
27
- standard: config_2.HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX,
15
+ export const SANDBOX_TYPE_MAP = {
16
+ dev: HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX,
17
+ developer: HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX,
18
+ development: HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX,
19
+ standard: HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX,
28
20
  };
29
- exports.SANDBOX_API_TYPE_MAP = {
30
- [config_2.HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX]: 1,
31
- [config_2.HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX]: 2,
21
+ export const SANDBOX_API_TYPE_MAP = {
22
+ [HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX]: 1,
23
+ [HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX]: 2,
32
24
  };
33
- function getSandboxTypeAsString(accountType) {
34
- if (accountType === config_2.HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX) {
25
+ export function getSandboxTypeAsString(accountType) {
26
+ if (accountType === HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX) {
35
27
  return 'development'; // Only place we're using this specific name
36
28
  }
37
29
  return 'standard';
38
30
  }
39
- function getHasSandboxesByType(parentAccountConfig, type) {
40
- const id = (0, getAccountIdentifier_1.getAccountIdentifier)(parentAccountConfig);
41
- const parentPortalId = (0, config_1.getAccountId)(id);
42
- const accountsList = (0, config_1.getConfigAccounts)() || [];
31
+ export function getHasSandboxesByType(parentAccountConfig, type) {
32
+ const id = getAccountIdentifier(parentAccountConfig);
33
+ const parentPortalId = getAccountId(id);
34
+ const accountsList = getConfigAccounts() || [];
43
35
  for (const portal of accountsList) {
44
36
  if ((portal.parentAccountId !== null ||
45
37
  portal.parentAccountId !== undefined) &&
@@ -52,44 +44,44 @@ function getHasSandboxesByType(parentAccountConfig, type) {
52
44
  return false;
53
45
  }
54
46
  // Fetches available sync types for a given sandbox portal
55
- async function getAvailableSyncTypes(parentAccountConfig, config) {
56
- const parentId = (0, getAccountIdentifier_1.getAccountIdentifier)(parentAccountConfig);
57
- const parentPortalId = (0, config_1.getAccountId)(parentId);
58
- const id = (0, getAccountIdentifier_1.getAccountIdentifier)(config);
59
- const portalId = (0, config_1.getAccountId)(id);
47
+ export async function getAvailableSyncTypes(parentAccountConfig, config) {
48
+ const parentId = getAccountIdentifier(parentAccountConfig);
49
+ const parentPortalId = getAccountId(parentId);
50
+ const id = getAccountIdentifier(config);
51
+ const portalId = getAccountId(id);
60
52
  if (!parentPortalId || !portalId) {
61
- throw new Error((0, lang_1.i18n)(`lib.sandbox.sync.failure.syncTypeFetch`));
53
+ throw new Error(i18n(`lib.sandbox.sync.failure.syncTypeFetch`));
62
54
  }
63
- const { data: { results: syncTypes }, } = await (0, sandboxSync_1.fetchTypes)(parentPortalId, portalId);
55
+ const { data: { results: syncTypes }, } = await fetchTypes(parentPortalId, portalId);
64
56
  if (!syncTypes) {
65
- throw new Error((0, lang_1.i18n)(`lib.sandbox.sync.failure.syncTypeFetch`));
57
+ throw new Error(i18n(`lib.sandbox.sync.failure.syncTypeFetch`));
66
58
  }
67
59
  return syncTypes.map(t => ({ type: t.name }));
68
60
  }
69
- async function validateSandboxUsageLimits(accountConfig, sandboxType, env) {
70
- const id = (0, getAccountIdentifier_1.getAccountIdentifier)(accountConfig);
71
- const accountId = (0, config_1.getAccountId)(id);
61
+ export async function validateSandboxUsageLimits(accountConfig, sandboxType, env) {
62
+ const id = getAccountIdentifier(accountConfig);
63
+ const accountId = getAccountId(id);
72
64
  if (!accountId) {
73
- throw new Error((0, lang_1.i18n)(`lib.sandbox.create.failure.usageLimitFetch`));
65
+ throw new Error(i18n(`lib.sandbox.create.failure.usageLimitFetch`));
74
66
  }
75
- const { data: { usage }, } = await (0, sandboxHubs_1.getSandboxUsageLimits)(accountId);
67
+ const { data: { usage }, } = await getSandboxUsageLimits(accountId);
76
68
  if (!usage) {
77
- throw new Error((0, lang_1.i18n)(`lib.sandbox.create.failure.usageLimitFetch`));
69
+ throw new Error(i18n(`lib.sandbox.create.failure.usageLimitFetch`));
78
70
  }
79
- if (sandboxType === config_2.HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX) {
71
+ if (sandboxType === HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX) {
80
72
  if (usage['DEVELOPER'].available === 0) {
81
73
  const devSandboxLimit = usage['DEVELOPER'].limit;
82
74
  const plural = devSandboxLimit !== 1;
83
- const hasDevelopmentSandboxes = getHasSandboxesByType(accountConfig, config_2.HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX);
75
+ const hasDevelopmentSandboxes = getHasSandboxesByType(accountConfig, HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX);
84
76
  if (hasDevelopmentSandboxes) {
85
- throw new Error((0, lang_1.i18n)(`lib.sandbox.create.failure.alreadyInConfig.developer.${plural ? 'other' : 'one'}`, {
77
+ throw new Error(i18n(`lib.sandbox.create.failure.alreadyInConfig.developer.${plural ? 'other' : 'one'}`, {
86
78
  accountName: accountConfig.name || accountId,
87
79
  limit: devSandboxLimit,
88
80
  }));
89
81
  }
90
82
  else {
91
- const baseUrl = (0, urls_1.getHubSpotWebsiteOrigin)(env);
92
- throw new Error((0, lang_1.i18n)(`lib.sandbox.create.failure.limit.developer.${plural ? 'other' : 'one'}`, {
83
+ const baseUrl = getHubSpotWebsiteOrigin(env);
84
+ throw new Error(i18n(`lib.sandbox.create.failure.limit.developer.${plural ? 'other' : 'one'}`, {
93
85
  accountName: accountConfig.name || accountId,
94
86
  limit: devSandboxLimit,
95
87
  link: `${baseUrl}/sandboxes-developer/${accountId}/development`,
@@ -97,20 +89,20 @@ async function validateSandboxUsageLimits(accountConfig, sandboxType, env) {
97
89
  }
98
90
  }
99
91
  }
100
- if (sandboxType === config_2.HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX) {
92
+ if (sandboxType === HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX) {
101
93
  if (usage['STANDARD'].available === 0) {
102
94
  const standardSandboxLimit = usage['STANDARD'].limit;
103
95
  const plural = standardSandboxLimit !== 1;
104
- const hasStandardSandboxes = getHasSandboxesByType(accountConfig, config_2.HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX);
96
+ const hasStandardSandboxes = getHasSandboxesByType(accountConfig, HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX);
105
97
  if (hasStandardSandboxes) {
106
- throw new Error((0, lang_1.i18n)(`lib.sandbox.create.failure.alreadyInConfig.standard.${plural ? 'other' : 'one'}`, {
98
+ throw new Error(i18n(`lib.sandbox.create.failure.alreadyInConfig.standard.${plural ? 'other' : 'one'}`, {
107
99
  accountName: accountConfig.name || accountId,
108
100
  limit: standardSandboxLimit,
109
101
  }));
110
102
  }
111
103
  else {
112
- const baseUrl = (0, urls_1.getHubSpotWebsiteOrigin)(env);
113
- throw new Error((0, lang_1.i18n)(`lib.sandbox.create.failure.limit.standard.${plural ? 'other' : 'one'}`, {
104
+ const baseUrl = getHubSpotWebsiteOrigin(env);
105
+ throw new Error(i18n(`lib.sandbox.create.failure.limit.standard.${plural ? 'other' : 'one'}`, {
114
106
  accountName: accountConfig.name || accountId,
115
107
  limit: standardSandboxLimit,
116
108
  link: `${baseUrl}/sandboxes-developer/${accountId}/standard`,
@@ -119,45 +111,45 @@ async function validateSandboxUsageLimits(accountConfig, sandboxType, env) {
119
111
  }
120
112
  }
121
113
  }
122
- function handleSandboxCreateError(err, env, name, accountId) {
123
- if ((0, index_1.isMissingScopeError)(err)) {
124
- logger_1.logger.error((0, lang_1.i18n)(`lib.sandbox.create.failure.scopes.message`, {
125
- accountName: (0, ui_1.uiAccountDescription)(accountId),
114
+ export function handleSandboxCreateError(err, env, name, accountId) {
115
+ if (isMissingScopeError(err)) {
116
+ logger.error(i18n(`lib.sandbox.create.failure.scopes.message`, {
117
+ accountName: uiAccountDescription(accountId),
126
118
  }));
127
- const websiteOrigin = (0, urls_1.getHubSpotWebsiteOrigin)(env);
119
+ const websiteOrigin = getHubSpotWebsiteOrigin(env);
128
120
  const url = `${websiteOrigin}/personal-access-key/${accountId}`;
129
- logger_1.logger.info((0, lang_1.i18n)(`lib.sandbox.create.failure.scopes.instructions`, {
130
- accountName: (0, ui_1.uiAccountDescription)(accountId),
121
+ logger.info(i18n(`lib.sandbox.create.failure.scopes.instructions`, {
122
+ accountName: uiAccountDescription(accountId),
131
123
  url,
132
124
  }));
133
125
  }
134
- else if ((0, index_1.isSpecifiedError)(err, {
126
+ else if (isSpecifiedError(err, {
135
127
  statusCode: 403,
136
128
  category: 'BANNED',
137
129
  subCategory: 'SandboxErrors.USER_ACCESS_NOT_ALLOWED',
138
130
  })) {
139
- logger_1.logger.log('');
140
- logger_1.logger.error((0, lang_1.i18n)(`lib.sandbox.create.failure.invalidUser`, {
131
+ logger.log('');
132
+ logger.error(i18n(`lib.sandbox.create.failure.invalidUser`, {
141
133
  accountName: name,
142
- parentAccountName: (0, ui_1.uiAccountDescription)(accountId),
134
+ parentAccountName: uiAccountDescription(accountId),
143
135
  }));
144
- logger_1.logger.log('');
136
+ logger.log('');
145
137
  }
146
- else if ((0, index_1.isSpecifiedError)(err, {
138
+ else if (isSpecifiedError(err, {
147
139
  statusCode: 403,
148
140
  category: 'BANNED',
149
141
  subCategory: 'SandboxErrors.DEVELOPMENT_SANDBOX_ACCESS_NOT_ALLOWED',
150
142
  })) {
151
- logger_1.logger.log('');
152
- logger_1.logger.error((0, lang_1.i18n)(`lib.sandbox.create.failure.403Gating`, {
143
+ logger.log('');
144
+ logger.error(i18n(`lib.sandbox.create.failure.403Gating`, {
153
145
  accountName: name,
154
- parentAccountName: (0, ui_1.uiAccountDescription)(accountId),
146
+ parentAccountName: uiAccountDescription(accountId),
155
147
  accountId,
156
148
  }));
157
- logger_1.logger.log('');
149
+ logger.log('');
158
150
  }
159
151
  else {
160
- (0, index_2.logError)(err);
152
+ logError(err);
161
153
  }
162
154
  throw err;
163
155
  }
package/lib/schema.js CHANGED
@@ -1,34 +1,23 @@
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
- exports.logSchemas = logSchemas;
7
- exports.listSchemas = listSchemas;
8
- const chalk_1 = __importDefault(require("chalk"));
9
- const table_1 = require("table");
10
- const logger_1 = require("@hubspot/local-dev-lib/logger");
11
- const customObjects_1 = require("@hubspot/local-dev-lib/api/customObjects");
12
- function logSchemas(schemas) {
1
+ import chalk from 'chalk';
2
+ import { table, getBorderCharacters } from 'table';
3
+ import { logger } from '@hubspot/local-dev-lib/logger';
4
+ import { fetchObjectSchemas } from '@hubspot/local-dev-lib/api/customObjects';
5
+ export function logSchemas(schemas) {
13
6
  const data = schemas
14
7
  .map(r => [r.labels.singular, r.name, r.objectTypeId || ''])
15
8
  .sort((a, b) => (a[1] > b[1] ? 1 : -1));
16
- if (data.length === 0) {
17
- logger_1.logger.log('No Schemas were found');
18
- return;
19
- }
20
9
  data.unshift([
21
- chalk_1.default.bold('Label'),
22
- chalk_1.default.bold('Name'),
23
- chalk_1.default.bold('objectTypeId'),
10
+ chalk.bold('Label'),
11
+ chalk.bold('Name'),
12
+ chalk.bold('objectTypeId'),
24
13
  ]);
25
14
  const tableConfig = {
26
15
  singleLine: true,
27
- border: (0, table_1.getBorderCharacters)('honeywell'),
16
+ border: getBorderCharacters('honeywell'),
28
17
  };
29
- logger_1.logger.log((0, table_1.table)(data, tableConfig));
18
+ logger.log(data.length ? table(data, tableConfig) : 'No Schemas were found');
30
19
  }
31
- async function listSchemas(accountId) {
32
- const { data } = await (0, customObjects_1.fetchObjectSchemas)(accountId);
20
+ export async function listSchemas(accountId) {
21
+ const { data } = await fetchObjectSchemas(accountId);
33
22
  logSchemas(data.results);
34
23
  }
@@ -1,23 +1,16 @@
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
- exports.tailLogs = tailLogs;
7
- exports.outputBuildLog = outputBuildLog;
8
- const https_1 = __importDefault(require("https"));
9
- const chalk_1 = __importDefault(require("chalk"));
10
- const logger_1 = require("@hubspot/local-dev-lib/logger");
11
- const index_1 = require("@hubspot/local-dev-lib/errors/index");
12
- const auth_1 = require("@hubspot/local-dev-lib/constants/auth");
13
- const config_1 = require("@hubspot/local-dev-lib/config");
14
- const localDevAuth_1 = require("@hubspot/local-dev-lib/api/localDevAuth");
15
- const serverlessFunctionLogs_1 = require("./ui/serverlessFunctionLogs");
16
- const index_2 = require("./errorHandlers/index");
17
- const SpinniesManager_1 = __importDefault(require("./ui/SpinniesManager"));
18
- const process_1 = require("./process");
19
- const exitCodes_1 = require("./enums/exitCodes");
20
- const lang_1 = require("./lang");
1
+ import https from 'https';
2
+ import chalk from 'chalk';
3
+ import { logger } from '@hubspot/local-dev-lib/logger';
4
+ import { isHubSpotHttpError, isMissingScopeError, } from '@hubspot/local-dev-lib/errors/index';
5
+ import { SCOPE_GROUPS, PERSONAL_ACCESS_KEY_AUTH_METHOD, } from '@hubspot/local-dev-lib/constants/auth';
6
+ import { getAccountConfig } from '@hubspot/local-dev-lib/config';
7
+ import { fetchScopeData } from '@hubspot/local-dev-lib/api/localDevAuth';
8
+ import { outputLogs } from './ui/serverlessFunctionLogs.js';
9
+ import { logError, ApiErrorContext } from './errorHandlers/index.js';
10
+ import SpinniesManager from './ui/SpinniesManager.js';
11
+ import { handleExit, handleKeypress } from './process.js';
12
+ import { EXIT_CODES } from './enums/exitCodes.js';
13
+ import { i18n } from './lang.js';
21
14
  const TAIL_DELAY = 5000;
22
15
  function base64EncodeString(valueToEncode) {
23
16
  if (typeof valueToEncode !== 'string') {
@@ -28,51 +21,51 @@ function base64EncodeString(valueToEncode) {
28
21
  }
29
22
  function handleUserInput() {
30
23
  const onTerminate = async () => {
31
- SpinniesManager_1.default.remove('tailLogs');
32
- SpinniesManager_1.default.remove('stopMessage');
33
- process.exit(exitCodes_1.EXIT_CODES.SUCCESS);
24
+ SpinniesManager.remove('tailLogs');
25
+ SpinniesManager.remove('stopMessage');
26
+ process.exit(EXIT_CODES.SUCCESS);
34
27
  };
35
- (0, process_1.handleExit)(onTerminate);
36
- (0, process_1.handleKeypress)(key => {
28
+ handleExit(onTerminate);
29
+ handleKeypress(key => {
37
30
  if ((key.ctrl && key.name == 'c') || key.name === 'q') {
38
31
  onTerminate();
39
32
  }
40
33
  });
41
34
  }
42
35
  async function verifyAccessKeyAndUserAccess(accountId, scopeGroup) {
43
- const accountConfig = (0, config_1.getAccountConfig)(accountId);
36
+ const accountConfig = getAccountConfig(accountId);
44
37
  if (!accountConfig) {
45
38
  return;
46
39
  }
47
40
  const { authType } = accountConfig;
48
- if (authType !== auth_1.PERSONAL_ACCESS_KEY_AUTH_METHOD.value) {
41
+ if (authType !== PERSONAL_ACCESS_KEY_AUTH_METHOD.value) {
49
42
  return;
50
43
  }
51
44
  let scopesData;
52
45
  try {
53
- const resp = await (0, localDevAuth_1.fetchScopeData)(accountId, scopeGroup);
46
+ const resp = await fetchScopeData(accountId, scopeGroup);
54
47
  scopesData = resp.data;
55
48
  }
56
49
  catch (e) {
57
- logger_1.logger.debug((0, lang_1.i18n)(`lib.serverless.verifyAccessKeyAndUserAccess.fetchScopeDataError`, {
50
+ logger.debug(i18n(`lib.serverless.verifyAccessKeyAndUserAccess.fetchScopeDataError`, {
58
51
  scopeGroup,
59
52
  }));
60
- logger_1.logger.debug(e);
53
+ logger.debug(e);
61
54
  return;
62
55
  }
63
56
  const { portalScopesInGroup, userScopesInGroup } = scopesData;
64
57
  if (!portalScopesInGroup.length) {
65
- logger_1.logger.error((0, lang_1.i18n)(`lib.serverless.verifyAccessKeyAndUserAccess.portalMissingScope`));
58
+ logger.error(i18n(`lib.serverless.verifyAccessKeyAndUserAccess.portalMissingScope`));
66
59
  return;
67
60
  }
68
61
  if (!portalScopesInGroup.every(s => userScopesInGroup.includes(s))) {
69
- logger_1.logger.error((0, lang_1.i18n)(`lib.serverless.verifyAccessKeyAndUserAccess.userMissingScope`));
62
+ logger.error(i18n(`lib.serverless.verifyAccessKeyAndUserAccess.userMissingScope`));
70
63
  }
71
64
  else {
72
- logger_1.logger.error((0, lang_1.i18n)(`lib.serverless.verifyAccessKeyAndUserAccess.genericMissingScope`));
65
+ logger.error(i18n(`lib.serverless.verifyAccessKeyAndUserAccess.genericMissingScope`));
73
66
  }
74
67
  }
75
- async function tailLogs(accountId, name, fetchLatest, tailCall, compact = false) {
68
+ export async function tailLogs(accountId, name, fetchLatest, tailCall, compact = false) {
76
69
  let initialAfter = '';
77
70
  try {
78
71
  const { data: latestLog } = await fetchLatest();
@@ -80,12 +73,12 @@ async function tailLogs(accountId, name, fetchLatest, tailCall, compact = false)
80
73
  }
81
74
  catch (e) {
82
75
  // A 404 means no latest log exists(never executed)
83
- if ((0, index_1.isHubSpotHttpError)(e) && e.status !== 404) {
84
- if ((0, index_1.isMissingScopeError)(e)) {
85
- await verifyAccessKeyAndUserAccess(accountId, auth_1.SCOPE_GROUPS.CMS_FUNCTIONS);
76
+ if (isHubSpotHttpError(e) && e.status !== 404) {
77
+ if (isMissingScopeError(e)) {
78
+ await verifyAccessKeyAndUserAccess(accountId, SCOPE_GROUPS.CMS_FUNCTIONS);
86
79
  }
87
80
  else {
88
- await (0, index_2.logError)(e, new index_2.ApiErrorContext({ accountId }));
81
+ await logError(e, new ApiErrorContext({ accountId }));
89
82
  }
90
83
  }
91
84
  }
@@ -98,15 +91,15 @@ async function tailLogs(accountId, name, fetchLatest, tailCall, compact = false)
98
91
  nextAfter = latestLog.paging.next.after;
99
92
  }
100
93
  catch (e) {
101
- if ((0, index_1.isHubSpotHttpError)(e) && e.status !== 404) {
102
- (0, index_2.logError)(e, new index_2.ApiErrorContext({
94
+ if (isHubSpotHttpError(e) && e.status !== 404) {
95
+ logError(e, new ApiErrorContext({
103
96
  accountId,
104
97
  }));
105
98
  }
106
- process.exit(exitCodes_1.EXIT_CODES.SUCCESS);
99
+ process.exit(EXIT_CODES.SUCCESS);
107
100
  }
108
101
  if (latestLog && latestLog.results.length) {
109
- (0, serverlessFunctionLogs_1.outputLogs)(latestLog, {
102
+ outputLogs(latestLog, {
110
103
  compact,
111
104
  });
112
105
  }
@@ -114,25 +107,25 @@ async function tailLogs(accountId, name, fetchLatest, tailCall, compact = false)
114
107
  await tail(nextAfter);
115
108
  }, TAIL_DELAY);
116
109
  }
117
- SpinniesManager_1.default.init();
118
- SpinniesManager_1.default.add('tailLogs', {
110
+ SpinniesManager.init();
111
+ SpinniesManager.add('tailLogs', {
119
112
  text: `Following logs for ${name}`,
120
113
  });
121
- SpinniesManager_1.default.add('stopMessage', {
122
- text: `> Press ${chalk_1.default.bold('q')} to stop following`,
114
+ SpinniesManager.add('stopMessage', {
115
+ text: `> Press ${chalk.bold('q')} to stop following`,
123
116
  status: 'non-spinnable',
124
117
  });
125
118
  handleUserInput();
126
119
  await tail(initialAfter);
127
120
  }
128
- async function outputBuildLog(buildLogUrl) {
121
+ export async function outputBuildLog(buildLogUrl) {
129
122
  if (!buildLogUrl) {
130
- logger_1.logger.debug('Unable to display build output. No build log URL was provided.');
123
+ logger.debug('Unable to display build output. No build log URL was provided.');
131
124
  return '';
132
125
  }
133
126
  return new Promise(resolve => {
134
127
  try {
135
- https_1.default
128
+ https
136
129
  .get(buildLogUrl, response => {
137
130
  if (response.statusCode === 404) {
138
131
  resolve('');
@@ -142,16 +135,16 @@ async function outputBuildLog(buildLogUrl) {
142
135
  data += chunk;
143
136
  });
144
137
  response.on('end', () => {
145
- logger_1.logger.log(data);
138
+ logger.log(data);
146
139
  resolve(data);
147
140
  });
148
141
  })
149
142
  .on('error', () => {
150
- logger_1.logger.error('The build log could not be retrieved.');
143
+ logger.error('The build log could not be retrieved.');
151
144
  });
152
145
  }
153
146
  catch (e) {
154
- logger_1.logger.error('The build log could not be retrieved.');
147
+ logger.error('The build log could not be retrieved.');
155
148
  resolve('');
156
149
  }
157
150
  });
package/lib/testUtils.js CHANGED
@@ -1,10 +1,6 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.mockHubSpotHttpResponse = mockHubSpotHttpResponse;
4
- exports.mockHubSpotHttpError = mockHubSpotHttpError;
5
- const HubSpotHttpError_1 = require("@hubspot/local-dev-lib/models/HubSpotHttpError");
1
+ import { HubSpotHttpError } from '@hubspot/local-dev-lib/models/HubSpotHttpError';
6
2
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
7
- function mockHubSpotHttpResponse(data) {
3
+ export function mockHubSpotHttpResponse(data) {
8
4
  return Promise.resolve({
9
5
  data,
10
6
  status: 200,
@@ -15,8 +11,8 @@ function mockHubSpotHttpResponse(data) {
15
11
  },
16
12
  });
17
13
  }
18
- function mockHubSpotHttpError(message, response) {
19
- return new HubSpotHttpError_1.HubSpotHttpError(message, {
14
+ export function mockHubSpotHttpError(message, response) {
15
+ return new HubSpotHttpError(message, {
20
16
  cause: { isAxiosError: true, response },
21
17
  });
22
18
  }
@@ -1,4 +1,4 @@
1
- import { SpinnerOptions as BaseSpinnerOptions, VALID_STATUSES } from './spinniesUtils';
1
+ import { SpinnerOptions as BaseSpinnerOptions, VALID_STATUSES } from './spinniesUtils.js';
2
2
  interface SpinnerState extends BaseSpinnerOptions {
3
3
  name?: string;
4
4
  }