@hubspot/cli 7.7.21-experimental.0 → 7.7.21-experimental.1

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 (570) hide show
  1. package/api/__tests__/migrate.test.js +29 -27
  2. package/api/migrate.js +22 -14
  3. package/bin/cli.js +101 -92
  4. package/bin/hs +2 -2
  5. package/bin/hscms +2 -2
  6. package/bin/silenceErrors.js +2 -1
  7. package/commands/__tests__/account.test.js +34 -29
  8. package/commands/__tests__/auth.test.js +16 -11
  9. package/commands/__tests__/cms.test.js +20 -15
  10. package/commands/__tests__/config.test.js +19 -14
  11. package/commands/__tests__/create.test.js +15 -10
  12. package/commands/__tests__/customObject.test.js +19 -14
  13. package/commands/__tests__/doctor.test.js +48 -43
  14. package/commands/__tests__/feedback.test.js +45 -7
  15. package/commands/__tests__/fetch.test.js +28 -29
  16. package/commands/__tests__/filemanager.test.js +19 -14
  17. package/commands/__tests__/function.test.js +21 -16
  18. package/commands/__tests__/getStarted.test.js +50 -55
  19. package/commands/__tests__/hubdb.test.js +22 -17
  20. package/commands/__tests__/init.test.js +17 -12
  21. package/commands/__tests__/lint.test.js +18 -13
  22. package/commands/__tests__/list.test.js +23 -18
  23. package/commands/__tests__/logs.test.js +27 -28
  24. package/commands/__tests__/mcp.test.js +19 -14
  25. package/commands/__tests__/mv.test.js +52 -14
  26. package/commands/__tests__/open.test.js +51 -13
  27. package/commands/__tests__/project.test.js +49 -44
  28. package/commands/__tests__/remove.test.js +51 -13
  29. package/commands/__tests__/sandbox.test.js +19 -14
  30. package/commands/__tests__/secret.test.js +21 -16
  31. package/commands/__tests__/testAccount.test.js +21 -16
  32. package/commands/__tests__/theme.test.js +20 -15
  33. package/commands/account/__tests__/auth.test.js +16 -11
  34. package/commands/account/__tests__/clean.test.js +17 -12
  35. package/commands/account/__tests__/createOverride.test.js +15 -10
  36. package/commands/account/__tests__/info.test.js +16 -11
  37. package/commands/account/__tests__/list.test.js +16 -11
  38. package/commands/account/__tests__/remove.test.js +18 -13
  39. package/commands/account/__tests__/removeOverride.js +13 -8
  40. package/commands/account/__tests__/rename.test.js +20 -15
  41. package/commands/account/__tests__/use.test.js +15 -10
  42. package/commands/account/auth.d.ts +1 -1
  43. package/commands/account/auth.js +67 -65
  44. package/commands/account/clean.d.ts +1 -1
  45. package/commands/account/clean.js +60 -55
  46. package/commands/account/createOverride.d.ts +1 -1
  47. package/commands/account/createOverride.js +57 -52
  48. package/commands/account/info.d.ts +1 -1
  49. package/commands/account/info.js +35 -33
  50. package/commands/account/list.d.ts +1 -1
  51. package/commands/account/list.js +45 -43
  52. package/commands/account/remove.d.ts +1 -1
  53. package/commands/account/remove.js +42 -37
  54. package/commands/account/removeOverride.d.ts +1 -1
  55. package/commands/account/removeOverride.js +43 -38
  56. package/commands/account/rename.d.ts +1 -1
  57. package/commands/account/rename.js +20 -18
  58. package/commands/account/use.d.ts +1 -1
  59. package/commands/account/use.js +31 -29
  60. package/commands/account.d.ts +1 -1
  61. package/commands/account.js +28 -23
  62. package/commands/app/__tests__/install.test.js +52 -0
  63. package/commands/app/__tests__/migrate.test.js +34 -29
  64. package/commands/app/install.d.ts +8 -0
  65. package/commands/app/install.js +127 -0
  66. package/commands/app/migrate.d.ts +2 -2
  67. package/commands/app/migrate.js +43 -40
  68. package/commands/app/secret/__tests__/add.test.js +11 -6
  69. package/commands/app/secret/__tests__/delete.test.js +11 -6
  70. package/commands/app/secret/__tests__/list.test.js +11 -6
  71. package/commands/app/secret/__tests__/update.test.js +11 -6
  72. package/commands/app/secret/add.d.ts +1 -1
  73. package/commands/app/secret/add.js +30 -28
  74. package/commands/app/secret/delete.d.ts +1 -1
  75. package/commands/app/secret/delete.js +36 -34
  76. package/commands/app/secret/list.d.ts +1 -1
  77. package/commands/app/secret/list.js +27 -25
  78. package/commands/app/secret/update.d.ts +1 -1
  79. package/commands/app/secret/update.js +34 -32
  80. package/commands/app/secret.d.ts +1 -1
  81. package/commands/app/secret.js +17 -12
  82. package/commands/app.d.ts +1 -1
  83. package/commands/app.js +16 -6
  84. package/commands/auth.d.ts +1 -1
  85. package/commands/auth.js +72 -70
  86. package/commands/cms/convertFields.d.ts +1 -1
  87. package/commands/cms/convertFields.js +39 -34
  88. package/commands/cms/getReactModule.d.ts +1 -1
  89. package/commands/cms/getReactModule.js +37 -32
  90. package/commands/cms/lighthouseScore.d.ts +1 -1
  91. package/commands/cms/lighthouseScore.js +72 -67
  92. package/commands/cms.d.ts +1 -1
  93. package/commands/cms.js +16 -11
  94. package/commands/completion.d.ts +1 -1
  95. package/commands/completion.js +15 -10
  96. package/commands/config/migrate.d.ts +1 -1
  97. package/commands/config/migrate.js +32 -27
  98. package/commands/config/set.d.ts +1 -1
  99. package/commands/config/set.js +25 -23
  100. package/commands/config.d.ts +1 -1
  101. package/commands/config.js +13 -8
  102. package/commands/create/api-sample.d.ts +1 -1
  103. package/commands/create/api-sample.js +33 -28
  104. package/commands/create/app.d.ts +1 -1
  105. package/commands/create/app.js +5 -3
  106. package/commands/create/function.d.ts +1 -1
  107. package/commands/create/function.js +11 -9
  108. package/commands/create/index.d.ts +1 -1
  109. package/commands/create/index.js +24 -19
  110. package/commands/create/module.d.ts +1 -1
  111. package/commands/create/module.js +14 -12
  112. package/commands/create/react-app.d.ts +1 -1
  113. package/commands/create/react-app.js +5 -3
  114. package/commands/create/template.d.ts +1 -1
  115. package/commands/create/template.js +14 -12
  116. package/commands/create/vue-app.d.ts +1 -1
  117. package/commands/create/vue-app.js +5 -3
  118. package/commands/create/webpack-serverless.d.ts +1 -1
  119. package/commands/create/webpack-serverless.js +5 -3
  120. package/commands/create/website-theme.d.ts +1 -1
  121. package/commands/create/website-theme.js +7 -5
  122. package/commands/create.d.ts +2 -2
  123. package/commands/create.js +35 -30
  124. package/commands/customObject/__tests__/create.test.js +18 -13
  125. package/commands/customObject/__tests__/schema.test.js +23 -18
  126. package/commands/customObject/create.d.ts +1 -1
  127. package/commands/customObject/create.js +30 -28
  128. package/commands/customObject/schema/__tests__/create.test.js +18 -13
  129. package/commands/customObject/schema/__tests__/delete.test.js +18 -13
  130. package/commands/customObject/schema/__tests__/fetch-all.test.js +18 -13
  131. package/commands/customObject/schema/__tests__/fetch.test.js +18 -13
  132. package/commands/customObject/schema/__tests__/list.test.js +18 -13
  133. package/commands/customObject/schema/__tests__/update.test.js +18 -13
  134. package/commands/customObject/schema/create.d.ts +1 -1
  135. package/commands/customObject/schema/create.js +30 -28
  136. package/commands/customObject/schema/delete.d.ts +1 -1
  137. package/commands/customObject/schema/delete.js +26 -24
  138. package/commands/customObject/schema/fetch-all.d.ts +1 -1
  139. package/commands/customObject/schema/fetch-all.js +24 -22
  140. package/commands/customObject/schema/fetch.d.ts +1 -1
  141. package/commands/customObject/schema/fetch.js +26 -24
  142. package/commands/customObject/schema/list.d.ts +1 -1
  143. package/commands/customObject/schema/list.js +15 -13
  144. package/commands/customObject/schema/update.d.ts +1 -1
  145. package/commands/customObject/schema/update.js +34 -32
  146. package/commands/customObject/schema.d.ts +1 -1
  147. package/commands/customObject/schema.js +22 -17
  148. package/commands/customObject.d.ts +1 -1
  149. package/commands/customObject.js +18 -13
  150. package/commands/doctor.d.ts +1 -1
  151. package/commands/doctor.js +33 -28
  152. package/commands/feedback.d.ts +1 -1
  153. package/commands/feedback.js +24 -19
  154. package/commands/fetch.d.ts +1 -1
  155. package/commands/fetch.js +30 -28
  156. package/commands/filemanager/__tests__/fetch.test.js +22 -17
  157. package/commands/filemanager/__tests__/upload.test.js +20 -15
  158. package/commands/filemanager/fetch.d.ts +1 -1
  159. package/commands/filemanager/fetch.js +25 -23
  160. package/commands/filemanager/upload.d.ts +1 -1
  161. package/commands/filemanager/upload.js +44 -39
  162. package/commands/filemanager.d.ts +1 -1
  163. package/commands/filemanager.js +13 -8
  164. package/commands/function/deploy.d.ts +1 -1
  165. package/commands/function/deploy.js +40 -35
  166. package/commands/function/list.d.ts +1 -1
  167. package/commands/function/list.js +29 -24
  168. package/commands/function/server.d.ts +1 -1
  169. package/commands/function/server.js +17 -15
  170. package/commands/function.d.ts +1 -1
  171. package/commands/function.js +18 -12
  172. package/commands/getStarted.d.ts +1 -1
  173. package/commands/getStarted.js +131 -140
  174. package/commands/hubdb/__tests__/clear.test.js +18 -13
  175. package/commands/hubdb/__tests__/create.test.js +18 -13
  176. package/commands/hubdb/__tests__/delete.test.js +18 -13
  177. package/commands/hubdb/__tests__/fetch.test.js +18 -13
  178. package/commands/hubdb/__tests__/list.test.js +28 -23
  179. package/commands/hubdb/clear.d.ts +1 -1
  180. package/commands/hubdb/clear.js +22 -20
  181. package/commands/hubdb/create.d.ts +1 -1
  182. package/commands/hubdb/create.js +35 -30
  183. package/commands/hubdb/delete.d.ts +1 -1
  184. package/commands/hubdb/delete.js +26 -24
  185. package/commands/hubdb/fetch.d.ts +1 -1
  186. package/commands/hubdb/fetch.js +19 -17
  187. package/commands/hubdb/list.d.ts +1 -1
  188. package/commands/hubdb/list.js +35 -33
  189. package/commands/hubdb.d.ts +1 -1
  190. package/commands/hubdb.js +24 -18
  191. package/commands/init.d.ts +1 -1
  192. package/commands/init.js +88 -83
  193. package/commands/lint.d.ts +1 -1
  194. package/commands/lint.js +26 -24
  195. package/commands/list.d.ts +1 -1
  196. package/commands/list.js +37 -32
  197. package/commands/logs.d.ts +1 -1
  198. package/commands/logs.js +37 -35
  199. package/commands/mcp/__tests__/setup.test.js +12 -7
  200. package/commands/mcp/__tests__/start.test.js +12 -7
  201. package/commands/mcp/setup.d.ts +1 -1
  202. package/commands/mcp/setup.js +20 -17
  203. package/commands/mcp/start.d.ts +5 -2
  204. package/commands/mcp/start.js +41 -31
  205. package/commands/mcp.d.ts +1 -1
  206. package/commands/mcp.js +12 -7
  207. package/commands/module/marketplace-validate.d.ts +1 -1
  208. package/commands/module/marketplace-validate.js +26 -21
  209. package/commands/module.d.ts +1 -1
  210. package/commands/module.js +13 -7
  211. package/commands/mv.d.ts +1 -1
  212. package/commands/mv.js +22 -20
  213. package/commands/open.d.ts +1 -1
  214. package/commands/open.js +21 -19
  215. package/commands/project/__tests__/add.test.js +15 -10
  216. package/commands/project/__tests__/create.test.js +19 -14
  217. package/commands/project/__tests__/deploy.test.js +143 -103
  218. package/commands/project/__tests__/devUnifiedFlow.test.js +157 -148
  219. package/commands/project/__tests__/download.test.js +19 -14
  220. package/commands/project/__tests__/installDeps.test.js +70 -32
  221. package/commands/project/__tests__/listBuilds.test.js +19 -14
  222. package/commands/project/__tests__/logs.test.js +94 -56
  223. package/commands/project/__tests__/migrate.test.js +30 -25
  224. package/commands/project/__tests__/migrateApp.test.js +22 -17
  225. package/commands/project/__tests__/open.test.js +21 -16
  226. package/commands/project/__tests__/profile.test.js +19 -14
  227. package/commands/project/__tests__/upload.test.js +23 -18
  228. package/commands/project/__tests__/watch.test.js +19 -14
  229. package/commands/project/add.d.ts +1 -1
  230. package/commands/project/add.js +36 -34
  231. package/commands/project/cloneApp.d.ts +1 -1
  232. package/commands/project/cloneApp.js +72 -67
  233. package/commands/project/create.d.ts +2 -2
  234. package/commands/project/create.js +68 -63
  235. package/commands/project/deploy.d.ts +3 -2
  236. package/commands/project/deploy.js +102 -91
  237. package/commands/project/dev/deprecatedFlow.d.ts +2 -2
  238. package/commands/project/dev/deprecatedFlow.js +58 -52
  239. package/commands/project/dev/index.d.ts +1 -1
  240. package/commands/project/dev/index.js +47 -44
  241. package/commands/project/dev/unifiedFlow.d.ts +3 -3
  242. package/commands/project/dev/unifiedFlow.js +74 -67
  243. package/commands/project/download.d.ts +1 -1
  244. package/commands/project/download.js +40 -35
  245. package/commands/project/installDeps.d.ts +1 -1
  246. package/commands/project/installDeps.js +34 -29
  247. package/commands/project/listBuilds.d.ts +1 -1
  248. package/commands/project/listBuilds.js +45 -40
  249. package/commands/project/logs.d.ts +1 -1
  250. package/commands/project/logs.js +54 -52
  251. package/commands/project/migrate.d.ts +1 -1
  252. package/commands/project/migrate.js +26 -24
  253. package/commands/project/migrateApp.d.ts +2 -2
  254. package/commands/project/migrateApp.js +20 -18
  255. package/commands/project/open.d.ts +1 -1
  256. package/commands/project/open.js +30 -25
  257. package/commands/project/profile/add.d.ts +1 -1
  258. package/commands/project/profile/add.js +73 -68
  259. package/commands/project/profile/delete.d.ts +1 -1
  260. package/commands/project/profile/delete.js +56 -51
  261. package/commands/project/profile.d.ts +1 -1
  262. package/commands/project/profile.js +14 -9
  263. package/commands/project/upload.d.ts +1 -1
  264. package/commands/project/upload.js +55 -50
  265. package/commands/project/validate.d.ts +1 -1
  266. package/commands/project/validate.js +40 -35
  267. package/commands/project/watch.d.ts +1 -1
  268. package/commands/project/watch.js +61 -59
  269. package/commands/project.d.ts +1 -1
  270. package/commands/project.js +43 -38
  271. package/commands/remove.d.ts +1 -1
  272. package/commands/remove.js +17 -15
  273. package/commands/sandbox/__tests__/create.test.js +20 -15
  274. package/commands/sandbox/__tests__/delete.test.js +20 -15
  275. package/commands/sandbox/create.d.ts +1 -1
  276. package/commands/sandbox/create.js +69 -67
  277. package/commands/sandbox/delete.d.ts +1 -1
  278. package/commands/sandbox/delete.js +96 -94
  279. package/commands/sandbox.d.ts +1 -1
  280. package/commands/sandbox.js +14 -9
  281. package/commands/secret/__tests__/addSecret.test.js +18 -13
  282. package/commands/secret/__tests__/deleteSecret.test.js +18 -13
  283. package/commands/secret/__tests__/listSecret.test.js +18 -13
  284. package/commands/secret/__tests__/updateSecret.test.js +18 -13
  285. package/commands/secret/addSecret.d.ts +1 -1
  286. package/commands/secret/addSecret.js +28 -26
  287. package/commands/secret/deleteSecret.d.ts +1 -1
  288. package/commands/secret/deleteSecret.js +29 -27
  289. package/commands/secret/listSecret.d.ts +1 -1
  290. package/commands/secret/listSecret.js +21 -19
  291. package/commands/secret/updateSecret.d.ts +1 -1
  292. package/commands/secret/updateSecret.js +27 -25
  293. package/commands/secret.d.ts +1 -1
  294. package/commands/secret.js +18 -13
  295. package/commands/testAccount/__tests__/create.test.js +22 -17
  296. package/commands/testAccount/__tests__/createConfig.test.js +11 -9
  297. package/commands/testAccount/__tests__/delete.test.js +20 -15
  298. package/commands/testAccount/create.d.ts +1 -1
  299. package/commands/testAccount/create.js +57 -62
  300. package/commands/testAccount/createConfig.d.ts +1 -3
  301. package/commands/testAccount/createConfig.js +47 -43
  302. package/commands/testAccount/delete.d.ts +1 -1
  303. package/commands/testAccount/delete.js +19 -17
  304. package/commands/testAccount.d.ts +1 -1
  305. package/commands/testAccount.js +15 -10
  306. package/commands/theme/__tests__/generate-selectors.test.js +12 -7
  307. package/commands/theme/__tests__/marketplace-validate.test.js +19 -14
  308. package/commands/theme/__tests__/preview.test.js +17 -12
  309. package/commands/theme/generate-selectors.d.ts +1 -1
  310. package/commands/theme/generate-selectors.js +28 -23
  311. package/commands/theme/marketplace-validate.d.ts +1 -1
  312. package/commands/theme/marketplace-validate.js +24 -19
  313. package/commands/theme/preview.d.ts +1 -1
  314. package/commands/theme/preview.js +65 -60
  315. package/commands/theme.d.ts +1 -1
  316. package/commands/theme.js +16 -11
  317. package/commands/upload.d.ts +1 -1
  318. package/commands/upload.js +82 -77
  319. package/commands/watch.d.ts +1 -1
  320. package/commands/watch.js +51 -45
  321. package/lang/en.d.ts +62 -23
  322. package/lang/en.js +434 -389
  323. package/lang/en.lyaml +0 -26
  324. package/lib/__tests__/accountTypes.test.js +22 -20
  325. package/lib/__tests__/buildAccount.test.js +90 -27
  326. package/lib/__tests__/commonOpts.test.js +22 -20
  327. package/lib/__tests__/dependencyManagement.test.js +51 -46
  328. package/lib/__tests__/developerTestAccounts.test.js +62 -27
  329. package/lib/__tests__/hasFeature.test.js +8 -6
  330. package/lib/__tests__/npm.test.js +20 -15
  331. package/lib/__tests__/oauth.test.js +28 -23
  332. package/lib/__tests__/parsing.test.js +20 -18
  333. package/lib/__tests__/polling.test.js +26 -24
  334. package/lib/__tests__/process.test.js +19 -14
  335. package/lib/__tests__/projectProfiles.test.js +39 -34
  336. package/lib/__tests__/sandboxSync.test.js +35 -30
  337. package/lib/__tests__/sandboxes.test.js +31 -29
  338. package/lib/__tests__/serverlessLogs.test.js +13 -8
  339. package/lib/__tests__/usageTracking.test.js +42 -47
  340. package/lib/__tests__/validation.test.js +20 -18
  341. package/lib/__tests__/yargsUtils.test.js +41 -6
  342. package/lib/accountTypes.js +34 -24
  343. package/lib/app/__tests__/migrate.test.js +99 -94
  344. package/lib/app/__tests__/migrate_legacy.test.js +31 -29
  345. package/lib/app/migrate.d.ts +3 -3
  346. package/lib/app/migrate.js +145 -127
  347. package/lib/app/migrate_legacy.d.ts +1 -1
  348. package/lib/app/migrate_legacy.js +78 -72
  349. package/lib/app/urls.js +9 -5
  350. package/lib/buildAccount.d.ts +8 -2
  351. package/lib/buildAccount.js +119 -61
  352. package/lib/commonOpts.d.ts +1 -1
  353. package/lib/commonOpts.js +59 -42
  354. package/lib/configMigrate.js +38 -34
  355. package/lib/configOptions.js +40 -34
  356. package/lib/constants.js +34 -31
  357. package/lib/customObject.js +6 -2
  358. package/lib/dependencyManagement.js +45 -37
  359. package/lib/developerTestAccounts.d.ts +1 -1
  360. package/lib/developerTestAccounts.js +39 -34
  361. package/lib/doctor/Diagnosis.d.ts +1 -1
  362. package/lib/doctor/Diagnosis.js +29 -25
  363. package/lib/doctor/DiagnosticInfoBuilder.d.ts +1 -1
  364. package/lib/doctor/DiagnosticInfoBuilder.js +37 -30
  365. package/lib/doctor/Doctor.d.ts +1 -1
  366. package/lib/doctor/Doctor.js +101 -94
  367. package/lib/doctor/__tests__/Diagnosis.test.js +14 -9
  368. package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.js +34 -29
  369. package/lib/doctor/__tests__/Doctor.test.js +26 -24
  370. package/lib/enums/exitCodes.js +4 -1
  371. package/lib/errorHandlers/index.js +41 -32
  372. package/lib/errorHandlers/suppressError.d.ts +1 -1
  373. package/lib/errorHandlers/suppressError.js +31 -28
  374. package/lib/filesystem.js +15 -8
  375. package/lib/generateSelectors.js +29 -18
  376. package/lib/hasFeature.d.ts +1 -1
  377. package/lib/hasFeature.js +6 -3
  378. package/lib/interpolation.js +18 -11
  379. package/lib/lang.d.ts +1 -1
  380. package/lib/lang.js +27 -22
  381. package/lib/links.js +24 -16
  382. package/lib/marketplaceValidate.js +39 -29
  383. package/lib/mcp/setup.js +105 -72
  384. package/lib/middleware/__test__/configMiddleware.test.js +55 -20
  385. package/lib/middleware/__test__/gitMiddleware.test.js +42 -7
  386. package/lib/middleware/__test__/notificationsMiddleware.test.js +4 -2
  387. package/lib/middleware/__test__/requestMiddleware.test.js +11 -6
  388. package/lib/middleware/__test__/utils.test.js +11 -9
  389. package/lib/middleware/__test__/yargsChecksMiddleware.test.js +44 -9
  390. package/lib/middleware/autoUpdateMiddleware.js +40 -33
  391. package/lib/middleware/configMiddleware.js +42 -36
  392. package/lib/middleware/fireAlarmMiddleware.js +18 -12
  393. package/lib/middleware/gitMiddleware.js +8 -5
  394. package/lib/middleware/notificationsMiddleware.js +23 -16
  395. package/lib/middleware/requestMiddleware.js +10 -4
  396. package/lib/middleware/utils.js +4 -1
  397. package/lib/middleware/yargsChecksMiddleware.js +13 -10
  398. package/lib/npm.js +23 -14
  399. package/lib/oauth.js +35 -29
  400. package/lib/parsing.js +6 -3
  401. package/lib/polling.js +15 -11
  402. package/lib/process.js +19 -11
  403. package/lib/projectProfiles.d.ts +2 -2
  404. package/lib/projectProfiles.js +42 -32
  405. package/lib/projects/ProjectLogsManager.js +21 -18
  406. package/lib/projects/__tests__/AppDevModeInterface.test.js +145 -140
  407. package/lib/projects/__tests__/LocalDevProcess.test.js +73 -68
  408. package/lib/projects/__tests__/LocalDevWebsocketServer.test.js +37 -32
  409. package/lib/projects/__tests__/ProjectLogsManager.test.js +58 -56
  410. package/lib/projects/__tests__/buildAndDeploy.test.js +9 -7
  411. package/lib/projects/__tests__/components.test.js +14 -9
  412. package/lib/projects/__tests__/projects.test.js +40 -35
  413. package/lib/projects/__tests__/structure.test.js +81 -43
  414. package/lib/projects/add/__tests__/legacyAddComponent.test.js +28 -26
  415. package/lib/projects/add/__tests__/v3AddComponent.test.js +30 -25
  416. package/lib/projects/add/legacyAddComponent.d.ts +1 -1
  417. package/lib/projects/add/legacyAddComponent.js +30 -24
  418. package/lib/projects/add/v3AddComponent.d.ts +1 -1
  419. package/lib/projects/add/v3AddComponent.js +42 -36
  420. package/lib/projects/buildAndDeploy.d.ts +1 -1
  421. package/lib/projects/buildAndDeploy.js +97 -88
  422. package/lib/projects/components.js +25 -19
  423. package/lib/projects/config.d.ts +1 -1
  424. package/lib/projects/config.js +41 -32
  425. package/lib/projects/create/__tests__/legacy.test.js +57 -22
  426. package/lib/projects/create/__tests__/v3.test.js +7 -5
  427. package/lib/projects/create/index.d.ts +3 -3
  428. package/lib/projects/create/index.js +22 -19
  429. package/lib/projects/create/legacy.d.ts +1 -1
  430. package/lib/projects/create/legacy.js +31 -25
  431. package/lib/projects/create/v3.d.ts +3 -3
  432. package/lib/projects/create/v3.js +59 -49
  433. package/lib/projects/ensureProjectExists.js +37 -31
  434. package/lib/projects/localDev/AppDevModeInterface.d.ts +3 -3
  435. package/lib/projects/localDev/AppDevModeInterface.js +60 -58
  436. package/lib/projects/localDev/DevServerManager.d.ts +1 -1
  437. package/lib/projects/localDev/DevServerManager.js +24 -24
  438. package/lib/projects/localDev/DevServerManagerV2.d.ts +2 -2
  439. package/lib/projects/localDev/DevServerManagerV2.js +20 -17
  440. package/lib/projects/localDev/LocalDevLogger.d.ts +1 -1
  441. package/lib/projects/localDev/LocalDevLogger.js +64 -59
  442. package/lib/projects/localDev/LocalDevManager.d.ts +1 -1
  443. package/lib/projects/localDev/LocalDevManager.js +111 -106
  444. package/lib/projects/localDev/LocalDevProcess.d.ts +4 -4
  445. package/lib/projects/localDev/LocalDevProcess.js +30 -25
  446. package/lib/projects/localDev/LocalDevState.d.ts +3 -3
  447. package/lib/projects/localDev/LocalDevState.js +5 -3
  448. package/lib/projects/localDev/LocalDevWatcher.d.ts +1 -1
  449. package/lib/projects/localDev/LocalDevWatcher.js +11 -6
  450. package/lib/projects/localDev/LocalDevWebsocketServer.d.ts +1 -1
  451. package/lib/projects/localDev/LocalDevWebsocketServer.js +27 -25
  452. package/lib/projects/localDev/helpers.d.ts +4 -4
  453. package/lib/projects/localDev/helpers.js +174 -156
  454. package/lib/projects/structure.d.ts +4 -4
  455. package/lib/projects/structure.js +78 -32
  456. package/lib/projects/ui.js +13 -10
  457. package/lib/projects/upload.d.ts +3 -2
  458. package/lib/projects/upload.js +65 -55
  459. package/lib/projects/urls.js +24 -14
  460. package/lib/projects/watch.d.ts +1 -1
  461. package/lib/projects/watch.js +54 -48
  462. package/lib/prompts/__tests__/downloadProjectPrompt.test.js +11 -9
  463. package/lib/prompts/__tests__/projectsLogsPrompt.test.js +16 -11
  464. package/lib/prompts/accountNamePrompt.d.ts +1 -1
  465. package/lib/prompts/accountNamePrompt.js +31 -26
  466. package/lib/prompts/accountsPrompt.js +15 -12
  467. package/lib/prompts/cmsFieldPrompt.js +19 -13
  468. package/lib/prompts/createApiSamplePrompt.d.ts +1 -1
  469. package/lib/prompts/createApiSamplePrompt.js +12 -9
  470. package/lib/prompts/createDeveloperTestAccountConfigPrompt.d.ts +11 -10
  471. package/lib/prompts/createDeveloperTestAccountConfigPrompt.js +88 -43
  472. package/lib/prompts/createFunctionPrompt.js +20 -17
  473. package/lib/prompts/createModulePrompt.js +15 -12
  474. package/lib/prompts/createTemplatePrompt.js +8 -5
  475. package/lib/prompts/downloadProjectPrompt.js +20 -17
  476. package/lib/prompts/installAppPrompt.js +26 -19
  477. package/lib/prompts/personalAccessKeyPrompt.d.ts +2 -2
  478. package/lib/prompts/personalAccessKeyPrompt.js +47 -40
  479. package/lib/prompts/previewPrompt.js +22 -15
  480. package/lib/prompts/projectAddPrompt.d.ts +1 -1
  481. package/lib/prompts/projectAddPrompt.js +18 -14
  482. package/lib/prompts/projectDevTargetAccountPrompt.d.ts +1 -1
  483. package/lib/prompts/projectDevTargetAccountPrompt.js +54 -48
  484. package/lib/prompts/projectNameAndDestPrompt.d.ts +1 -1
  485. package/lib/prompts/projectNameAndDestPrompt.js +29 -22
  486. package/lib/prompts/projectNamePrompt.js +14 -11
  487. package/lib/prompts/projectsLogsPrompt.js +8 -5
  488. package/lib/prompts/promptUtils.d.ts +1 -1
  489. package/lib/prompts/promptUtils.js +87 -70
  490. package/lib/prompts/sandboxesPrompt.d.ts +1 -1
  491. package/lib/prompts/sandboxesPrompt.js +30 -26
  492. package/lib/prompts/secretPrompt.js +15 -10
  493. package/lib/prompts/selectAppPrompt.js +14 -11
  494. package/lib/prompts/selectHubDBTablePrompt.js +30 -24
  495. package/lib/prompts/selectProjectTemplatePrompt.d.ts +1 -1
  496. package/lib/prompts/selectProjectTemplatePrompt.js +13 -10
  497. package/lib/prompts/selectPublicAppForMigrationPrompt.js +25 -22
  498. package/lib/prompts/setAsDefaultAccountPrompt.js +16 -13
  499. package/lib/prompts/uploadPrompt.js +17 -11
  500. package/lib/sandboxSync.d.ts +1 -1
  501. package/lib/sandboxSync.js +65 -58
  502. package/lib/sandboxes.d.ts +1 -1
  503. package/lib/sandboxes.js +76 -68
  504. package/lib/schema.js +23 -12
  505. package/lib/serverlessLogs.js +52 -45
  506. package/lib/testUtils.js +8 -4
  507. package/lib/ui/SpinniesManager.d.ts +1 -1
  508. package/lib/ui/SpinniesManager.js +34 -29
  509. package/lib/ui/boxen.js +14 -11
  510. package/lib/ui/git.js +20 -14
  511. package/lib/ui/index.js +74 -56
  512. package/lib/ui/logger.js +13 -10
  513. package/lib/ui/serverlessFunctionLogs.js +20 -14
  514. package/lib/ui/spinniesUtils.js +39 -24
  515. package/lib/ui/supportHyperlinks.js +6 -3
  516. package/lib/ui/supportsColor.js +17 -11
  517. package/lib/ui/table.js +13 -6
  518. package/lib/upload.js +21 -15
  519. package/lib/usageTracking.d.ts +11 -0
  520. package/lib/usageTracking.js +95 -95
  521. package/lib/utils/hasFlag.js +8 -2
  522. package/lib/validation.js +87 -48
  523. package/lib/yargsUtils.d.ts +1 -1
  524. package/lib/yargsUtils.js +16 -13
  525. package/mcp-server/server.js +8 -6
  526. package/mcp-server/tools/index.js +16 -13
  527. package/mcp-server/tools/project/AddFeatureToProject.d.ts +1 -1
  528. package/mcp-server/tools/project/AddFeatureToProject.js +41 -34
  529. package/mcp-server/tools/project/CreateProjectTool.d.ts +3 -3
  530. package/mcp-server/tools/project/CreateProjectTool.js +52 -45
  531. package/mcp-server/tools/project/DeployProject.d.ts +1 -1
  532. package/mcp-server/tools/project/DeployProject.js +24 -17
  533. package/mcp-server/tools/project/GuidedWalkthroughTool.d.ts +1 -1
  534. package/mcp-server/tools/project/GuidedWalkthroughTool.js +27 -20
  535. package/mcp-server/tools/project/UploadProjectTools.d.ts +1 -1
  536. package/mcp-server/tools/project/UploadProjectTools.js +21 -11
  537. package/mcp-server/tools/project/ValidateProjectTool.d.ts +1 -1
  538. package/mcp-server/tools/project/ValidateProjectTool.js +19 -12
  539. package/mcp-server/tools/project/__tests__/AddFeatureToProject.test.js +15 -12
  540. package/mcp-server/tools/project/__tests__/CreateProjectTool.test.js +16 -13
  541. package/mcp-server/tools/project/__tests__/DeployProject.test.js +9 -6
  542. package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.js +7 -4
  543. package/mcp-server/tools/project/__tests__/UploadProjectTools.test.js +7 -4
  544. package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.js +7 -4
  545. package/mcp-server/tools/project/constants.js +9 -3
  546. package/mcp-server/types.js +5 -1
  547. package/mcp-server/utils/__tests__/command.test.js +11 -9
  548. package/mcp-server/utils/__tests__/project.test.js +26 -18
  549. package/mcp-server/utils/command.d.ts +1 -1
  550. package/mcp-server/utils/command.js +11 -4
  551. package/mcp-server/utils/content.d.ts +1 -1
  552. package/mcp-server/utils/content.js +6 -2
  553. package/mcp-server/utils/project.js +17 -8
  554. package/mcp-server/utils/toolUsageTracking.d.ts +1 -0
  555. package/mcp-server/utils/toolUsageTracking.js +25 -0
  556. package/package.json +13 -17
  557. package/types/{cms.d.ts → Cms.d.ts} +1 -1
  558. package/types/Cms.js +2 -0
  559. package/types/LocalDev.d.ts +4 -4
  560. package/types/LocalDev.js +2 -1
  561. package/types/ProjectComponents.d.ts +2 -2
  562. package/types/ProjectComponents.js +2 -1
  563. package/types/Projects.d.ts +1 -1
  564. package/types/Projects.js +5 -2
  565. package/types/Prompts.js +2 -1
  566. package/types/Sandboxes.js +2 -0
  567. package/types/Yargs.js +2 -1
  568. package/types/sandboxes.js +0 -1
  569. /package/{types/cms.js → commands/app/__tests__/install.test.d.ts} +0 -0
  570. /package/types/{sandboxes.d.ts → Sandboxes.d.ts} +0 -0
package/lib/sandboxes.js CHANGED
@@ -1,37 +1,45 @@
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 = {
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 = {
13
21
  OBJECT_RECORDS: 'object-records',
14
22
  };
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,
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,
20
28
  };
21
- export const SANDBOX_API_TYPE_MAP = {
22
- [HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX]: 1,
23
- [HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX]: 2,
29
+ exports.SANDBOX_API_TYPE_MAP = {
30
+ [config_2.HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX]: 1,
31
+ [config_2.HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX]: 2,
24
32
  };
25
- export function getSandboxTypeAsString(accountType) {
26
- if (accountType === HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX) {
33
+ function getSandboxTypeAsString(accountType) {
34
+ if (accountType === config_2.HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX) {
27
35
  return 'development'; // Only place we're using this specific name
28
36
  }
29
37
  return 'standard';
30
38
  }
31
- export function getHasSandboxesByType(parentAccountConfig, type) {
32
- const id = getAccountIdentifier(parentAccountConfig);
33
- const parentPortalId = getAccountId(id);
34
- const accountsList = getConfigAccounts() || [];
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)() || [];
35
43
  for (const portal of accountsList) {
36
44
  if ((portal.parentAccountId !== null ||
37
45
  portal.parentAccountId !== undefined) &&
@@ -44,44 +52,44 @@ export function getHasSandboxesByType(parentAccountConfig, type) {
44
52
  return false;
45
53
  }
46
54
  // Fetches available sync types for a given sandbox portal
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);
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);
52
60
  if (!parentPortalId || !portalId) {
53
- throw new Error(i18n(`lib.sandbox.sync.failure.syncTypeFetch`));
61
+ throw new Error((0, lang_1.i18n)(`lib.sandbox.sync.failure.syncTypeFetch`));
54
62
  }
55
- const { data: { results: syncTypes }, } = await fetchTypes(parentPortalId, portalId);
63
+ const { data: { results: syncTypes }, } = await (0, sandboxSync_1.fetchTypes)(parentPortalId, portalId);
56
64
  if (!syncTypes) {
57
- throw new Error(i18n(`lib.sandbox.sync.failure.syncTypeFetch`));
65
+ throw new Error((0, lang_1.i18n)(`lib.sandbox.sync.failure.syncTypeFetch`));
58
66
  }
59
67
  return syncTypes.map(t => ({ type: t.name }));
60
68
  }
61
- export async function validateSandboxUsageLimits(accountConfig, sandboxType, env) {
62
- const id = getAccountIdentifier(accountConfig);
63
- const accountId = getAccountId(id);
69
+ async function validateSandboxUsageLimits(accountConfig, sandboxType, env) {
70
+ const id = (0, getAccountIdentifier_1.getAccountIdentifier)(accountConfig);
71
+ const accountId = (0, config_1.getAccountId)(id);
64
72
  if (!accountId) {
65
- throw new Error(i18n(`lib.sandbox.create.failure.usageLimitFetch`));
73
+ throw new Error((0, lang_1.i18n)(`lib.sandbox.create.failure.usageLimitFetch`));
66
74
  }
67
- const { data: { usage }, } = await getSandboxUsageLimits(accountId);
75
+ const { data: { usage }, } = await (0, sandboxHubs_1.getSandboxUsageLimits)(accountId);
68
76
  if (!usage) {
69
- throw new Error(i18n(`lib.sandbox.create.failure.usageLimitFetch`));
77
+ throw new Error((0, lang_1.i18n)(`lib.sandbox.create.failure.usageLimitFetch`));
70
78
  }
71
- if (sandboxType === HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX) {
79
+ if (sandboxType === config_2.HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX) {
72
80
  if (usage['DEVELOPER'].available === 0) {
73
81
  const devSandboxLimit = usage['DEVELOPER'].limit;
74
82
  const plural = devSandboxLimit !== 1;
75
- const hasDevelopmentSandboxes = getHasSandboxesByType(accountConfig, HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX);
83
+ const hasDevelopmentSandboxes = getHasSandboxesByType(accountConfig, config_2.HUBSPOT_ACCOUNT_TYPES.DEVELOPMENT_SANDBOX);
76
84
  if (hasDevelopmentSandboxes) {
77
- throw new Error(i18n(`lib.sandbox.create.failure.alreadyInConfig.developer.${plural ? 'other' : 'one'}`, {
85
+ throw new Error((0, lang_1.i18n)(`lib.sandbox.create.failure.alreadyInConfig.developer.${plural ? 'other' : 'one'}`, {
78
86
  accountName: accountConfig.name || accountId,
79
87
  limit: devSandboxLimit,
80
88
  }));
81
89
  }
82
90
  else {
83
- const baseUrl = getHubSpotWebsiteOrigin(env);
84
- throw new Error(i18n(`lib.sandbox.create.failure.limit.developer.${plural ? 'other' : 'one'}`, {
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'}`, {
85
93
  accountName: accountConfig.name || accountId,
86
94
  limit: devSandboxLimit,
87
95
  link: `${baseUrl}/sandboxes-developer/${accountId}/development`,
@@ -89,20 +97,20 @@ export async function validateSandboxUsageLimits(accountConfig, sandboxType, env
89
97
  }
90
98
  }
91
99
  }
92
- if (sandboxType === HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX) {
100
+ if (sandboxType === config_2.HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX) {
93
101
  if (usage['STANDARD'].available === 0) {
94
102
  const standardSandboxLimit = usage['STANDARD'].limit;
95
103
  const plural = standardSandboxLimit !== 1;
96
- const hasStandardSandboxes = getHasSandboxesByType(accountConfig, HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX);
104
+ const hasStandardSandboxes = getHasSandboxesByType(accountConfig, config_2.HUBSPOT_ACCOUNT_TYPES.STANDARD_SANDBOX);
97
105
  if (hasStandardSandboxes) {
98
- throw new Error(i18n(`lib.sandbox.create.failure.alreadyInConfig.standard.${plural ? 'other' : 'one'}`, {
106
+ throw new Error((0, lang_1.i18n)(`lib.sandbox.create.failure.alreadyInConfig.standard.${plural ? 'other' : 'one'}`, {
99
107
  accountName: accountConfig.name || accountId,
100
108
  limit: standardSandboxLimit,
101
109
  }));
102
110
  }
103
111
  else {
104
- const baseUrl = getHubSpotWebsiteOrigin(env);
105
- throw new Error(i18n(`lib.sandbox.create.failure.limit.standard.${plural ? 'other' : 'one'}`, {
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'}`, {
106
114
  accountName: accountConfig.name || accountId,
107
115
  limit: standardSandboxLimit,
108
116
  link: `${baseUrl}/sandboxes-developer/${accountId}/standard`,
@@ -111,45 +119,45 @@ export async function validateSandboxUsageLimits(accountConfig, sandboxType, env
111
119
  }
112
120
  }
113
121
  }
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),
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),
118
126
  }));
119
- const websiteOrigin = getHubSpotWebsiteOrigin(env);
127
+ const websiteOrigin = (0, urls_1.getHubSpotWebsiteOrigin)(env);
120
128
  const url = `${websiteOrigin}/personal-access-key/${accountId}`;
121
- logger.info(i18n(`lib.sandbox.create.failure.scopes.instructions`, {
122
- accountName: uiAccountDescription(accountId),
129
+ logger_1.logger.info((0, lang_1.i18n)(`lib.sandbox.create.failure.scopes.instructions`, {
130
+ accountName: (0, ui_1.uiAccountDescription)(accountId),
123
131
  url,
124
132
  }));
125
133
  }
126
- else if (isSpecifiedError(err, {
134
+ else if ((0, index_1.isSpecifiedError)(err, {
127
135
  statusCode: 403,
128
136
  category: 'BANNED',
129
137
  subCategory: 'SandboxErrors.USER_ACCESS_NOT_ALLOWED',
130
138
  })) {
131
- logger.log('');
132
- logger.error(i18n(`lib.sandbox.create.failure.invalidUser`, {
139
+ logger_1.logger.log('');
140
+ logger_1.logger.error((0, lang_1.i18n)(`lib.sandbox.create.failure.invalidUser`, {
133
141
  accountName: name,
134
- parentAccountName: uiAccountDescription(accountId),
142
+ parentAccountName: (0, ui_1.uiAccountDescription)(accountId),
135
143
  }));
136
- logger.log('');
144
+ logger_1.logger.log('');
137
145
  }
138
- else if (isSpecifiedError(err, {
146
+ else if ((0, index_1.isSpecifiedError)(err, {
139
147
  statusCode: 403,
140
148
  category: 'BANNED',
141
149
  subCategory: 'SandboxErrors.DEVELOPMENT_SANDBOX_ACCESS_NOT_ALLOWED',
142
150
  })) {
143
- logger.log('');
144
- logger.error(i18n(`lib.sandbox.create.failure.403Gating`, {
151
+ logger_1.logger.log('');
152
+ logger_1.logger.error((0, lang_1.i18n)(`lib.sandbox.create.failure.403Gating`, {
145
153
  accountName: name,
146
- parentAccountName: uiAccountDescription(accountId),
154
+ parentAccountName: (0, ui_1.uiAccountDescription)(accountId),
147
155
  accountId,
148
156
  }));
149
- logger.log('');
157
+ logger_1.logger.log('');
150
158
  }
151
159
  else {
152
- logError(err);
160
+ (0, index_2.logError)(err);
153
161
  }
154
162
  throw err;
155
163
  }
package/lib/schema.js CHANGED
@@ -1,23 +1,34 @@
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) {
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) {
6
13
  const data = schemas
7
14
  .map(r => [r.labels.singular, r.name, r.objectTypeId || ''])
8
15
  .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
+ }
9
20
  data.unshift([
10
- chalk.bold('Label'),
11
- chalk.bold('Name'),
12
- chalk.bold('objectTypeId'),
21
+ chalk_1.default.bold('Label'),
22
+ chalk_1.default.bold('Name'),
23
+ chalk_1.default.bold('objectTypeId'),
13
24
  ]);
14
25
  const tableConfig = {
15
26
  singleLine: true,
16
- border: getBorderCharacters('honeywell'),
27
+ border: (0, table_1.getBorderCharacters)('honeywell'),
17
28
  };
18
- logger.log(data.length ? table(data, tableConfig) : 'No Schemas were found');
29
+ logger_1.logger.log((0, table_1.table)(data, tableConfig));
19
30
  }
20
- export async function listSchemas(accountId) {
21
- const { data } = await fetchObjectSchemas(accountId);
31
+ async function listSchemas(accountId) {
32
+ const { data } = await (0, customObjects_1.fetchObjectSchemas)(accountId);
22
33
  logSchemas(data.results);
23
34
  }
@@ -1,16 +1,23 @@
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';
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");
14
21
  const TAIL_DELAY = 5000;
15
22
  function base64EncodeString(valueToEncode) {
16
23
  if (typeof valueToEncode !== 'string') {
@@ -21,51 +28,51 @@ function base64EncodeString(valueToEncode) {
21
28
  }
22
29
  function handleUserInput() {
23
30
  const onTerminate = async () => {
24
- SpinniesManager.remove('tailLogs');
25
- SpinniesManager.remove('stopMessage');
26
- process.exit(EXIT_CODES.SUCCESS);
31
+ SpinniesManager_1.default.remove('tailLogs');
32
+ SpinniesManager_1.default.remove('stopMessage');
33
+ process.exit(exitCodes_1.EXIT_CODES.SUCCESS);
27
34
  };
28
- handleExit(onTerminate);
29
- handleKeypress(key => {
35
+ (0, process_1.handleExit)(onTerminate);
36
+ (0, process_1.handleKeypress)(key => {
30
37
  if ((key.ctrl && key.name == 'c') || key.name === 'q') {
31
38
  onTerminate();
32
39
  }
33
40
  });
34
41
  }
35
42
  async function verifyAccessKeyAndUserAccess(accountId, scopeGroup) {
36
- const accountConfig = getAccountConfig(accountId);
43
+ const accountConfig = (0, config_1.getAccountConfig)(accountId);
37
44
  if (!accountConfig) {
38
45
  return;
39
46
  }
40
47
  const { authType } = accountConfig;
41
- if (authType !== PERSONAL_ACCESS_KEY_AUTH_METHOD.value) {
48
+ if (authType !== auth_1.PERSONAL_ACCESS_KEY_AUTH_METHOD.value) {
42
49
  return;
43
50
  }
44
51
  let scopesData;
45
52
  try {
46
- const resp = await fetchScopeData(accountId, scopeGroup);
53
+ const resp = await (0, localDevAuth_1.fetchScopeData)(accountId, scopeGroup);
47
54
  scopesData = resp.data;
48
55
  }
49
56
  catch (e) {
50
- logger.debug(i18n(`lib.serverless.verifyAccessKeyAndUserAccess.fetchScopeDataError`, {
57
+ logger_1.logger.debug((0, lang_1.i18n)(`lib.serverless.verifyAccessKeyAndUserAccess.fetchScopeDataError`, {
51
58
  scopeGroup,
52
59
  }));
53
- logger.debug(e);
60
+ logger_1.logger.debug(e);
54
61
  return;
55
62
  }
56
63
  const { portalScopesInGroup, userScopesInGroup } = scopesData;
57
64
  if (!portalScopesInGroup.length) {
58
- logger.error(i18n(`lib.serverless.verifyAccessKeyAndUserAccess.portalMissingScope`));
65
+ logger_1.logger.error((0, lang_1.i18n)(`lib.serverless.verifyAccessKeyAndUserAccess.portalMissingScope`));
59
66
  return;
60
67
  }
61
68
  if (!portalScopesInGroup.every(s => userScopesInGroup.includes(s))) {
62
- logger.error(i18n(`lib.serverless.verifyAccessKeyAndUserAccess.userMissingScope`));
69
+ logger_1.logger.error((0, lang_1.i18n)(`lib.serverless.verifyAccessKeyAndUserAccess.userMissingScope`));
63
70
  }
64
71
  else {
65
- logger.error(i18n(`lib.serverless.verifyAccessKeyAndUserAccess.genericMissingScope`));
72
+ logger_1.logger.error((0, lang_1.i18n)(`lib.serverless.verifyAccessKeyAndUserAccess.genericMissingScope`));
66
73
  }
67
74
  }
68
- export async function tailLogs(accountId, name, fetchLatest, tailCall, compact = false) {
75
+ async function tailLogs(accountId, name, fetchLatest, tailCall, compact = false) {
69
76
  let initialAfter = '';
70
77
  try {
71
78
  const { data: latestLog } = await fetchLatest();
@@ -73,12 +80,12 @@ export async function tailLogs(accountId, name, fetchLatest, tailCall, compact =
73
80
  }
74
81
  catch (e) {
75
82
  // A 404 means no latest log exists(never executed)
76
- if (isHubSpotHttpError(e) && e.status !== 404) {
77
- if (isMissingScopeError(e)) {
78
- await verifyAccessKeyAndUserAccess(accountId, SCOPE_GROUPS.CMS_FUNCTIONS);
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);
79
86
  }
80
87
  else {
81
- await logError(e, new ApiErrorContext({ accountId }));
88
+ await (0, index_2.logError)(e, new index_2.ApiErrorContext({ accountId }));
82
89
  }
83
90
  }
84
91
  }
@@ -91,15 +98,15 @@ export async function tailLogs(accountId, name, fetchLatest, tailCall, compact =
91
98
  nextAfter = latestLog.paging.next.after;
92
99
  }
93
100
  catch (e) {
94
- if (isHubSpotHttpError(e) && e.status !== 404) {
95
- logError(e, new ApiErrorContext({
101
+ if ((0, index_1.isHubSpotHttpError)(e) && e.status !== 404) {
102
+ (0, index_2.logError)(e, new index_2.ApiErrorContext({
96
103
  accountId,
97
104
  }));
98
105
  }
99
- process.exit(EXIT_CODES.SUCCESS);
106
+ process.exit(exitCodes_1.EXIT_CODES.SUCCESS);
100
107
  }
101
108
  if (latestLog && latestLog.results.length) {
102
- outputLogs(latestLog, {
109
+ (0, serverlessFunctionLogs_1.outputLogs)(latestLog, {
103
110
  compact,
104
111
  });
105
112
  }
@@ -107,25 +114,25 @@ export async function tailLogs(accountId, name, fetchLatest, tailCall, compact =
107
114
  await tail(nextAfter);
108
115
  }, TAIL_DELAY);
109
116
  }
110
- SpinniesManager.init();
111
- SpinniesManager.add('tailLogs', {
117
+ SpinniesManager_1.default.init();
118
+ SpinniesManager_1.default.add('tailLogs', {
112
119
  text: `Following logs for ${name}`,
113
120
  });
114
- SpinniesManager.add('stopMessage', {
115
- text: `> Press ${chalk.bold('q')} to stop following`,
121
+ SpinniesManager_1.default.add('stopMessage', {
122
+ text: `> Press ${chalk_1.default.bold('q')} to stop following`,
116
123
  status: 'non-spinnable',
117
124
  });
118
125
  handleUserInput();
119
126
  await tail(initialAfter);
120
127
  }
121
- export async function outputBuildLog(buildLogUrl) {
128
+ async function outputBuildLog(buildLogUrl) {
122
129
  if (!buildLogUrl) {
123
- logger.debug('Unable to display build output. No build log URL was provided.');
130
+ logger_1.logger.debug('Unable to display build output. No build log URL was provided.');
124
131
  return '';
125
132
  }
126
133
  return new Promise(resolve => {
127
134
  try {
128
- https
135
+ https_1.default
129
136
  .get(buildLogUrl, response => {
130
137
  if (response.statusCode === 404) {
131
138
  resolve('');
@@ -135,16 +142,16 @@ export async function outputBuildLog(buildLogUrl) {
135
142
  data += chunk;
136
143
  });
137
144
  response.on('end', () => {
138
- logger.log(data);
145
+ logger_1.logger.log(data);
139
146
  resolve(data);
140
147
  });
141
148
  })
142
149
  .on('error', () => {
143
- logger.error('The build log could not be retrieved.');
150
+ logger_1.logger.error('The build log could not be retrieved.');
144
151
  });
145
152
  }
146
153
  catch (e) {
147
- logger.error('The build log could not be retrieved.');
154
+ logger_1.logger.error('The build log could not be retrieved.');
148
155
  resolve('');
149
156
  }
150
157
  });
package/lib/testUtils.js CHANGED
@@ -1,6 +1,10 @@
1
- import { HubSpotHttpError } from '@hubspot/local-dev-lib/models/HubSpotHttpError';
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");
2
6
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
3
- export function mockHubSpotHttpResponse(data) {
7
+ function mockHubSpotHttpResponse(data) {
4
8
  return Promise.resolve({
5
9
  data,
6
10
  status: 200,
@@ -11,8 +15,8 @@ export function mockHubSpotHttpResponse(data) {
11
15
  },
12
16
  });
13
17
  }
14
- export function mockHubSpotHttpError(message, response) {
15
- return new HubSpotHttpError(message, {
18
+ function mockHubSpotHttpError(message, response) {
19
+ return new HubSpotHttpError_1.HubSpotHttpError(message, {
16
20
  cause: { isAxiosError: true, response },
17
21
  });
18
22
  }
@@ -1,4 +1,4 @@
1
- import { SpinnerOptions as BaseSpinnerOptions, VALID_STATUSES } from './spinniesUtils.js';
1
+ import { SpinnerOptions as BaseSpinnerOptions, VALID_STATUSES } from './spinniesUtils';
2
2
  interface SpinnerState extends BaseSpinnerOptions {
3
3
  name?: string;
4
4
  }