@hubspot/cli 8.2.0-beta.0 → 8.2.0-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.
- package/api/migrate.js +8 -4
- package/api/releases.d.ts +36 -0
- package/api/releases.js +41 -0
- package/bin/cli.js +12 -6
- package/commands/account/auth.d.ts +3 -1
- package/commands/account/auth.js +23 -7
- package/commands/account/clean.js +7 -6
- package/commands/account/createOverride.js +10 -7
- package/commands/account/info.js +36 -17
- package/commands/account/link.d.ts +4 -0
- package/commands/account/link.js +87 -0
- package/commands/account/list.js +32 -76
- package/commands/account/remove.js +4 -3
- package/commands/account/removeOverride.js +11 -10
- package/commands/account/rename.js +5 -6
- package/commands/account/unlink.d.ts +4 -0
- package/commands/account/unlink.js +68 -0
- package/commands/account/use.js +75 -6
- package/commands/account.js +4 -0
- package/commands/api.d.ts +10 -0
- package/commands/api.js +164 -0
- package/commands/app/logDetails.d.ts +9 -0
- package/commands/app/logDetails.js +86 -0
- package/commands/app/logs.d.ts +13 -0
- package/commands/app/logs.js +122 -0
- package/commands/app/migrate.js +13 -13
- package/commands/app/secret/add.js +6 -7
- package/commands/app/secret/delete.js +9 -10
- package/commands/app/secret/list.js +6 -7
- package/commands/app/secret/update.js +8 -9
- package/commands/app.js +8 -1
- package/commands/auth.js +20 -16
- package/commands/cms/app/create.js +9 -5
- package/commands/cms/convertFields.js +8 -8
- package/commands/cms/delete.js +2 -3
- package/commands/cms/fetch.js +7 -7
- package/commands/cms/function/create.js +9 -5
- package/commands/cms/function/deploy.js +2 -3
- package/commands/cms/function/list.js +11 -7
- package/commands/cms/function/logs.js +17 -23
- package/commands/cms/function/server.js +2 -3
- package/commands/cms/getReactModule.js +7 -8
- package/commands/cms/lighthouseScore.js +25 -24
- package/commands/cms/lint.js +4 -5
- package/commands/cms/list.js +5 -6
- package/commands/cms/module/create.js +15 -5
- package/commands/cms/module/marketplace-validate.js +7 -8
- package/commands/cms/mv.js +2 -3
- package/commands/cms/template/create.js +10 -6
- package/commands/cms/theme/create.js +5 -5
- package/commands/cms/theme/generate-selectors.js +5 -4
- package/commands/cms/theme/marketplace-validate.js +8 -9
- package/commands/cms/theme/preview.js +16 -8
- package/commands/cms/upload.js +15 -12
- package/commands/cms/watch.js +5 -5
- package/commands/cms/webpack/create.js +5 -5
- package/commands/completion.js +3 -5
- package/commands/config/migrate.js +6 -7
- package/commands/config/set.js +5 -6
- package/commands/customObject/create.js +4 -5
- package/commands/customObject/createSchema.js +4 -5
- package/commands/customObject/deleteSchema.js +4 -5
- package/commands/customObject/fetchAllSchemas.js +2 -3
- package/commands/customObject/fetchSchema.js +2 -3
- package/commands/customObject/listSchemas.js +2 -3
- package/commands/customObject/updateSchema.js +4 -5
- package/commands/doctor.js +8 -8
- package/commands/feedback.js +6 -4
- package/commands/filemanager/fetch.js +5 -6
- package/commands/filemanager/upload.js +5 -5
- package/commands/getStarted.js +17 -19
- package/commands/hubdb/clear.js +6 -3
- package/commands/hubdb/create.js +4 -5
- package/commands/hubdb/delete.js +9 -6
- package/commands/hubdb/fetch.js +6 -3
- package/commands/hubdb/list.js +16 -14
- package/commands/init.js +16 -15
- package/commands/mcp/setup.js +5 -6
- package/commands/mcp/start.js +2 -3
- package/commands/open.js +4 -5
- package/commands/project/add.js +13 -8
- package/commands/project/appInstallStatus.d.ts +4 -0
- package/commands/project/appInstallStatus.js +133 -0
- package/commands/project/create.js +28 -17
- package/commands/project/delete.d.ts +7 -0
- package/commands/project/delete.js +74 -0
- package/commands/project/deploy.js +39 -36
- package/commands/project/dev/deprecatedFlow.js +62 -17
- package/commands/project/dev/index.d.ts +3 -3
- package/commands/project/dev/index.js +59 -48
- package/commands/project/dev/unifiedFlow.js +70 -21
- package/commands/project/download.js +12 -9
- package/commands/project/info.d.ts +4 -0
- package/commands/project/info.js +68 -0
- package/commands/project/installDeps.js +9 -6
- package/commands/project/lint.js +43 -12
- package/commands/project/list.d.ts +2 -2
- package/commands/project/list.js +15 -14
- package/commands/project/listBuilds.js +8 -6
- package/commands/project/logs.js +5 -6
- package/commands/project/migrate.js +18 -18
- package/commands/project/open.js +5 -6
- package/commands/project/profile/add.js +12 -8
- package/commands/project/profile/delete.js +15 -11
- package/commands/project/release/create.d.ts +7 -0
- package/commands/project/release/create.js +159 -0
- package/commands/project/release/info.d.ts +6 -0
- package/commands/project/release/info.js +147 -0
- package/commands/project/release/list.d.ts +6 -0
- package/commands/project/release/list.js +111 -0
- package/commands/project/release.d.ts +3 -0
- package/commands/project/release.js +20 -0
- package/commands/project/updateDeps.js +9 -6
- package/commands/project/upload.d.ts +3 -0
- package/commands/project/upload.js +107 -25
- package/commands/project/validate.js +12 -12
- package/commands/project/watch.js +22 -22
- package/commands/project.js +14 -3
- package/commands/sandbox/create.js +18 -45
- package/commands/sandbox/delete.js +13 -14
- package/commands/secret/addSecret.js +6 -7
- package/commands/secret/deleteSecret.js +5 -6
- package/commands/secret/listSecret.js +2 -3
- package/commands/secret/updateSecret.js +4 -5
- package/commands/testAccount/create.d.ts +1 -1
- package/commands/testAccount/create.js +25 -17
- package/commands/testAccount/createConfig.js +7 -8
- package/commands/testAccount/delete.js +27 -18
- package/commands/testAccount/importData.js +6 -7
- package/commands/upgrade.js +9 -10
- package/lang/en.d.ts +441 -9
- package/lang/en.js +456 -22
- package/lib/CLIWebSocketServer.d.ts +5 -3
- package/lib/CLIWebSocketServer.js +31 -4
- package/lib/accountAuth.d.ts +3 -1
- package/lib/accountAuth.js +47 -17
- package/lib/api/usageTracking.d.ts +30 -0
- package/lib/api/usageTracking.js +11 -0
- package/lib/app/logs.d.ts +38 -0
- package/lib/app/logs.js +225 -0
- package/lib/app/migrate.js +18 -5
- package/lib/app/urls.d.ts +2 -0
- package/lib/app/urls.js +7 -0
- package/lib/auth/awaitPersonalAccessKeyOverWebsocket.d.ts +4 -0
- package/lib/auth/awaitPersonalAccessKeyOverWebsocket.js +145 -0
- package/lib/buildAccount.d.ts +1 -6
- package/lib/buildAccount.js +10 -43
- package/lib/commonOpts.js +0 -1
- package/lib/constants.d.ts +10 -3
- package/lib/constants.js +12 -3
- package/lib/doctor/Diagnosis.js +5 -5
- package/lib/doctor/Doctor.js +7 -7
- package/lib/errorHandlers/index.js +4 -3
- package/lib/errorHandlers/suppressError.js +4 -0
- package/lib/errors/PromptExitError.d.ts +6 -0
- package/lib/errors/PromptExitError.js +11 -0
- package/lib/getStartedV2Actions.js +3 -3
- package/lib/hasFeature.js +1 -2
- package/lib/link/accountTableUtils.d.ts +10 -0
- package/lib/link/accountTableUtils.js +39 -0
- package/lib/link/index.d.ts +18 -0
- package/lib/link/index.js +185 -0
- package/lib/link/linkUtils.d.ts +5 -0
- package/lib/link/linkUtils.js +49 -0
- package/lib/link/prompts.d.ts +7 -0
- package/lib/link/prompts.js +126 -0
- package/lib/link/renderLinkedAccountsTable.d.ts +2 -0
- package/lib/link/renderLinkedAccountsTable.js +14 -0
- package/lib/link/warnIfLinkedDirectory.d.ts +1 -0
- package/lib/link/warnIfLinkedDirectory.js +9 -0
- package/lib/middleware/autoUpdateMiddleware.js +6 -3
- package/lib/middleware/commandTargetingUtils.js +1 -0
- package/lib/process.d.ts +1 -1
- package/lib/process.js +10 -3
- package/lib/projects/ProjectLogsManager.js +6 -3
- package/lib/projects/components.js +15 -4
- package/lib/projects/create/index.js +2 -2
- package/lib/projects/create/legacy.js +2 -2
- package/lib/projects/create/v2.js +4 -5
- package/lib/projects/delete.d.ts +13 -0
- package/lib/projects/delete.js +193 -0
- package/lib/projects/deploy.d.ts +1 -1
- package/lib/projects/deploy.js +2 -2
- package/lib/projects/localDev/AppDevModeInterface.js +13 -9
- package/lib/projects/localDev/DevServerManager_DEPRECATED.d.ts +4 -1
- package/lib/projects/localDev/DevServerManager_DEPRECATED.js +3 -3
- package/lib/projects/localDev/DevSessionManager.d.ts +6 -3
- package/lib/projects/localDev/DevSessionManager.js +31 -19
- package/lib/projects/localDev/LocalDevManager_DEPRECATED.d.ts +5 -0
- package/lib/projects/localDev/LocalDevManager_DEPRECATED.js +21 -10
- package/lib/projects/localDev/LocalDevProcess.js +6 -5
- package/lib/projects/localDev/LocalDevState.d.ts +3 -2
- package/lib/projects/localDev/LocalDevState.js +3 -1
- package/lib/projects/localDev/LocalDevWebsocketServer.js +1 -1
- package/lib/projects/localDev/UIExtensionsDevModeInterface.js +2 -0
- package/lib/projects/localDev/helpers/account.d.ts +4 -3
- package/lib/projects/localDev/helpers/account.js +21 -30
- package/lib/projects/localDev/helpers/process.d.ts +1 -1
- package/lib/projects/localDev/helpers/process.js +4 -10
- package/lib/projects/localDev/helpers/project.d.ts +4 -3
- package/lib/projects/localDev/helpers/project.js +32 -16
- package/lib/projects/npmAuditOnUpload.d.ts +10 -0
- package/lib/projects/npmAuditOnUpload.js +73 -0
- package/lib/projects/pollProjectBuildAndDeploy.d.ts +5 -1
- package/lib/projects/pollProjectBuildAndDeploy.js +3 -2
- package/lib/projects/preview.d.ts +7 -0
- package/lib/projects/preview.js +48 -0
- package/lib/projects/projectInfo.d.ts +5 -0
- package/lib/projects/projectInfo.js +82 -0
- package/lib/projects/projectProfiles.d.ts +1 -2
- package/lib/projects/projectProfiles.js +5 -17
- package/lib/projects/uieLinting.d.ts +21 -3
- package/lib/projects/uieLinting.js +132 -28
- package/lib/projects/upload.d.ts +3 -1
- package/lib/projects/upload.js +46 -7
- package/lib/projects/validateLintConfigOnUpload.d.ts +9 -0
- package/lib/projects/validateLintConfigOnUpload.js +45 -0
- package/lib/projects/workspaces.d.ts +60 -0
- package/lib/projects/workspaces.js +411 -0
- package/lib/prompts/createApiSamplePrompt.js +4 -0
- package/lib/prompts/downloadProjectPrompt.js +11 -10
- package/lib/prompts/installAppPrompt.js +3 -2
- package/lib/prompts/personalAccessKeyPrompt.d.ts +2 -5
- package/lib/prompts/personalAccessKeyPrompt.js +10 -7
- package/lib/prompts/projectDevTargetAccountPrompt.d.ts +1 -0
- package/lib/prompts/projectDevTargetAccountPrompt.js +23 -16
- package/lib/prompts/projectProfilePrompt.d.ts +2 -0
- package/lib/prompts/projectProfilePrompt.js +46 -0
- package/lib/prompts/projectsLogsPrompt.js +3 -0
- package/lib/prompts/promptUtils.js +4 -2
- package/lib/prompts/selectAppPrompt.js +1 -0
- package/lib/prompts/selectHubDBTablePrompt.js +8 -4
- package/lib/prompts/selectPublicAppForMigrationPrompt.js +12 -6
- package/lib/prompts/setAsDefaultAccountPrompt.js +2 -1
- package/lib/sandboxes.d.ts +1 -9
- package/lib/sandboxes.js +0 -21
- package/lib/serverlessLogs.js +2 -2
- package/lib/theme/cmsDevServerProcess.d.ts +2 -0
- package/lib/theme/cmsDevServerProcess.js +8 -7
- package/lib/theme/migrate.d.ts +1 -1
- package/lib/theme/migrate.js +1 -5
- package/lib/ui/SpinniesManager.d.ts +1 -0
- package/lib/ui/SpinniesManager.js +22 -6
- package/lib/ui/accountTable.d.ts +8 -0
- package/lib/ui/accountTable.js +67 -0
- package/lib/ui/appLogs.d.ts +32 -0
- package/lib/ui/appLogs.js +175 -0
- package/lib/ui/spinniesUtils.d.ts +0 -1
- package/lib/ui/spinniesUtils.js +6 -16
- package/lib/usageTracking.d.ts +9 -20
- package/lib/usageTracking.js +68 -30
- package/lib/yargs/makeWrappedYargsHandler.d.ts +3 -0
- package/lib/yargs/makeWrappedYargsHandler.js +121 -0
- package/lib/yargs/makeYargsBuilder.d.ts +13 -0
- package/lib/yargs/makeYargsBuilder.js +33 -0
- package/lib/yargs/parseYargsOrExit.d.ts +4 -0
- package/lib/yargs/parseYargsOrExit.js +25 -0
- package/lib/yargs/strictEnforceBoolean.d.ts +1 -0
- package/lib/yargs/strictEnforceBoolean.js +13 -0
- package/lib/yargsUtils.d.ts +3 -16
- package/lib/yargsUtils.js +3 -48
- package/mcp-server/Tool.d.ts +15 -0
- package/mcp-server/Tool.js +53 -0
- package/mcp-server/server.js +43 -3
- package/mcp-server/tools/cms/HsCreateFunctionTool.d.ts +4 -2
- package/mcp-server/tools/cms/HsCreateFunctionTool.js +10 -8
- package/mcp-server/tools/cms/HsCreateModuleTool.d.ts +4 -2
- package/mcp-server/tools/cms/HsCreateModuleTool.js +12 -11
- package/mcp-server/tools/cms/HsCreateTemplateTool.d.ts +4 -2
- package/mcp-server/tools/cms/HsCreateTemplateTool.js +10 -8
- package/mcp-server/tools/cms/HsFunctionLogsTool.d.ts +4 -2
- package/mcp-server/tools/cms/HsFunctionLogsTool.js +10 -9
- package/mcp-server/tools/cms/HsListFunctionsTool.d.ts +4 -2
- package/mcp-server/tools/cms/HsListFunctionsTool.js +10 -9
- package/mcp-server/tools/cms/HsListTool.d.ts +4 -2
- package/mcp-server/tools/cms/HsListTool.js +10 -8
- package/mcp-server/tools/index.d.ts +3 -2
- package/mcp-server/tools/index.js +24 -22
- package/mcp-server/tools/project/AddFeatureToProjectTool.d.ts +6 -3
- package/mcp-server/tools/project/AddFeatureToProjectTool.js +9 -7
- package/mcp-server/tools/project/CreateProjectTool.d.ts +6 -3
- package/mcp-server/tools/project/CreateProjectTool.js +10 -7
- package/mcp-server/tools/project/CreateTestAccountTool.d.ts +4 -2
- package/mcp-server/tools/project/CreateTestAccountTool.js +21 -9
- package/mcp-server/tools/project/DeployProjectTool.d.ts +4 -2
- package/mcp-server/tools/project/DeployProjectTool.js +5 -7
- package/mcp-server/tools/project/DocFetchTool.d.ts +4 -2
- package/mcp-server/tools/project/DocFetchTool.js +8 -6
- package/mcp-server/tools/project/DocsSearchTool.d.ts +9 -3
- package/mcp-server/tools/project/DocsSearchTool.js +32 -9
- package/mcp-server/tools/project/FindProjectsTool.d.ts +15 -0
- package/mcp-server/tools/project/FindProjectsTool.js +60 -0
- package/mcp-server/tools/project/GetApiUsagePatternsByAppIdTool.d.ts +4 -2
- package/mcp-server/tools/project/GetApiUsagePatternsByAppIdTool.js +8 -6
- package/mcp-server/tools/project/GetApplicationInfoTool.d.ts +4 -2
- package/mcp-server/tools/project/GetApplicationInfoTool.js +8 -6
- package/mcp-server/tools/project/GetBuildLogsTool.d.ts +4 -2
- package/mcp-server/tools/project/GetBuildLogsTool.js +9 -7
- package/mcp-server/tools/project/GetBuildStatusTool.d.ts +4 -2
- package/mcp-server/tools/project/GetBuildStatusTool.js +9 -7
- package/mcp-server/tools/project/GetConfigValuesTool.d.ts +4 -2
- package/mcp-server/tools/project/GetConfigValuesTool.js +12 -7
- package/mcp-server/tools/project/GuidedWalkthroughTool.d.ts +4 -2
- package/mcp-server/tools/project/GuidedWalkthroughTool.js +4 -6
- package/mcp-server/tools/project/UploadProjectTools.d.ts +4 -2
- package/mcp-server/tools/project/UploadProjectTools.js +10 -8
- package/mcp-server/tools/project/ValidateProjectTool.d.ts +4 -2
- package/mcp-server/tools/project/ValidateProjectTool.js +9 -7
- package/mcp-server/tools/project/constants.d.ts +2 -1
- package/mcp-server/tools/project/constants.js +2 -1
- package/mcp-server/types.d.ts +0 -7
- package/mcp-server/types.js +1 -13
- package/mcp-server/utils/command.js +3 -1
- package/mcp-server/utils/config.js +1 -0
- package/mcp-server/utils/logger.d.ts +10 -0
- package/mcp-server/utils/logger.js +29 -0
- package/mcp-server/utils/toolUsageTracking.js +10 -8
- package/package.json +16 -11
- package/types/Link.d.ts +32 -0
- package/types/Link.js +5 -0
- package/types/LocalDev.d.ts +5 -0
- package/types/PackageJson.d.ts +1 -0
- package/types/Projects.d.ts +19 -0
- package/types/Prompts.d.ts +1 -0
- package/types/Yargs.d.ts +19 -1
- package/ui/components/ActionSection.d.ts +1 -1
- package/ui/components/InputField.d.ts +1 -1
- package/ui/components/SelectInput.d.ts +1 -1
- package/ui/components/StatusIcon.d.ts +1 -1
- package/ui/components/Table.d.ts +5 -5
- package/ui/components/getStarted/GetStartedFlow.d.ts +1 -1
- package/ui/components/getStarted/screens/InstallationScreen.d.ts +1 -1
- package/ui/components/getStarted/screens/ProjectSetupScreen.d.ts +1 -1
- package/ui/components/getStarted/screens/UploadScreen.d.ts +1 -1
- package/api/__tests__/migrate.test.d.ts +0 -1
- package/api/__tests__/migrate.test.js +0 -199
- package/commands/__tests__/account.test.d.ts +0 -1
- package/commands/__tests__/account.test.js +0 -69
- package/commands/__tests__/auth.test.d.ts +0 -1
- package/commands/__tests__/auth.test.js +0 -43
- package/commands/__tests__/cms.test.d.ts +0 -1
- package/commands/__tests__/cms.test.js +0 -87
- package/commands/__tests__/config.test.d.ts +0 -1
- package/commands/__tests__/config.test.js +0 -44
- package/commands/__tests__/customObject.test.d.ts +0 -1
- package/commands/__tests__/customObject.test.js +0 -68
- package/commands/__tests__/doctor.test.d.ts +0 -1
- package/commands/__tests__/doctor.test.js +0 -132
- package/commands/__tests__/feedback.test.d.ts +0 -1
- package/commands/__tests__/feedback.test.js +0 -24
- package/commands/__tests__/filemanager.test.d.ts +0 -1
- package/commands/__tests__/filemanager.test.js +0 -45
- package/commands/__tests__/getStarted.test.d.ts +0 -1
- package/commands/__tests__/getStarted.test.js +0 -173
- package/commands/__tests__/hubdb.test.d.ts +0 -1
- package/commands/__tests__/hubdb.test.js +0 -50
- package/commands/__tests__/init.test.d.ts +0 -1
- package/commands/__tests__/init.test.js +0 -42
- package/commands/__tests__/mcp.test.d.ts +0 -1
- package/commands/__tests__/mcp.test.js +0 -46
- package/commands/__tests__/open.test.d.ts +0 -1
- package/commands/__tests__/open.test.js +0 -58
- package/commands/__tests__/project.test.d.ts +0 -1
- package/commands/__tests__/project.test.js +0 -125
- package/commands/__tests__/sandbox.test.d.ts +0 -1
- package/commands/__tests__/sandbox.test.js +0 -44
- package/commands/__tests__/secret.test.d.ts +0 -1
- package/commands/__tests__/secret.test.js +0 -49
- package/commands/__tests__/testAccount.test.d.ts +0 -1
- package/commands/__tests__/testAccount.test.js +0 -57
- package/commands/__tests__/upgrade.test.d.ts +0 -1
- package/commands/__tests__/upgrade.test.js +0 -309
- package/commands/account/__tests__/auth.test.d.ts +0 -1
- package/commands/account/__tests__/auth.test.js +0 -206
- package/commands/account/__tests__/clean.test.d.ts +0 -1
- package/commands/account/__tests__/clean.test.js +0 -28
- package/commands/account/__tests__/createOverride.test.d.ts +0 -1
- package/commands/account/__tests__/createOverride.test.js +0 -32
- package/commands/account/__tests__/info.test.d.ts +0 -1
- package/commands/account/__tests__/info.test.js +0 -28
- package/commands/account/__tests__/list.test.d.ts +0 -1
- package/commands/account/__tests__/list.test.js +0 -153
- package/commands/account/__tests__/remove.test.d.ts +0 -1
- package/commands/account/__tests__/remove.test.js +0 -36
- package/commands/account/__tests__/removeOverride.d.ts +0 -1
- package/commands/account/__tests__/removeOverride.js +0 -25
- package/commands/account/__tests__/rename.test.d.ts +0 -1
- package/commands/account/__tests__/rename.test.js +0 -82
- package/commands/account/__tests__/use.test.d.ts +0 -1
- package/commands/account/__tests__/use.test.js +0 -170
- package/commands/app/__tests__/migrate.test.d.ts +0 -1
- package/commands/app/__tests__/migrate.test.js +0 -111
- package/commands/app/secret/__tests__/add.test.d.ts +0 -1
- package/commands/app/secret/__tests__/add.test.js +0 -140
- package/commands/app/secret/__tests__/delete.test.d.ts +0 -1
- package/commands/app/secret/__tests__/delete.test.js +0 -28
- package/commands/app/secret/__tests__/list.test.d.ts +0 -1
- package/commands/app/secret/__tests__/list.test.js +0 -25
- package/commands/app/secret/__tests__/update.test.d.ts +0 -1
- package/commands/app/secret/__tests__/update.test.js +0 -28
- package/commands/cms/__tests__/delete.test.d.ts +0 -1
- package/commands/cms/__tests__/delete.test.js +0 -39
- package/commands/cms/__tests__/fetch.test.d.ts +0 -1
- package/commands/cms/__tests__/fetch.test.js +0 -156
- package/commands/cms/__tests__/function.test.d.ts +0 -1
- package/commands/cms/__tests__/function.test.js +0 -50
- package/commands/cms/__tests__/lint.test.d.ts +0 -1
- package/commands/cms/__tests__/lint.test.js +0 -33
- package/commands/cms/__tests__/list.test.d.ts +0 -1
- package/commands/cms/__tests__/list.test.js +0 -42
- package/commands/cms/__tests__/module.test.d.ts +0 -1
- package/commands/cms/__tests__/module.test.js +0 -45
- package/commands/cms/__tests__/mv.test.d.ts +0 -1
- package/commands/cms/__tests__/mv.test.js +0 -46
- package/commands/cms/__tests__/theme.test.d.ts +0 -1
- package/commands/cms/__tests__/theme.test.js +0 -54
- package/commands/cms/__tests__/upload.test.d.ts +0 -1
- package/commands/cms/__tests__/upload.test.js +0 -308
- package/commands/cms/__tests__/watch.test.d.ts +0 -1
- package/commands/cms/__tests__/watch.test.js +0 -204
- package/commands/cms/function/__tests__/logs.test.d.ts +0 -1
- package/commands/cms/function/__tests__/logs.test.js +0 -70
- package/commands/cms/theme/__tests__/generate-selectors.test.d.ts +0 -1
- package/commands/cms/theme/__tests__/generate-selectors.test.js +0 -28
- package/commands/cms/theme/__tests__/marketplace-validate.test.d.ts +0 -1
- package/commands/cms/theme/__tests__/marketplace-validate.test.js +0 -36
- package/commands/cms/theme/__tests__/preview.test.d.ts +0 -1
- package/commands/cms/theme/__tests__/preview.test.js +0 -54
- package/commands/customObject/__tests__/create.test.d.ts +0 -1
- package/commands/customObject/__tests__/create.test.js +0 -40
- package/commands/customObject/__tests__/createSchema.test.d.ts +0 -1
- package/commands/customObject/__tests__/createSchema.test.js +0 -28
- package/commands/customObject/__tests__/deleteSchema.test.d.ts +0 -1
- package/commands/customObject/__tests__/deleteSchema.test.js +0 -42
- package/commands/customObject/__tests__/fetch-all-schemas.test.d.ts +0 -1
- package/commands/customObject/__tests__/fetch-all-schemas.test.js +0 -41
- package/commands/customObject/__tests__/fetchSchema.test.d.ts +0 -1
- package/commands/customObject/__tests__/fetchSchema.test.js +0 -45
- package/commands/customObject/__tests__/listSchemas.test.d.ts +0 -1
- package/commands/customObject/__tests__/listSchemas.test.js +0 -29
- package/commands/customObject/__tests__/updateSchema.test.d.ts +0 -1
- package/commands/customObject/__tests__/updateSchema.test.js +0 -40
- package/commands/filemanager/__tests__/fetch.test.d.ts +0 -1
- package/commands/filemanager/__tests__/fetch.test.js +0 -32
- package/commands/filemanager/__tests__/upload.test.d.ts +0 -1
- package/commands/filemanager/__tests__/upload.test.js +0 -191
- package/commands/hubdb/__tests__/clear.test.d.ts +0 -1
- package/commands/hubdb/__tests__/clear.test.js +0 -28
- package/commands/hubdb/__tests__/create.test.d.ts +0 -1
- package/commands/hubdb/__tests__/create.test.js +0 -28
- package/commands/hubdb/__tests__/delete.test.d.ts +0 -1
- package/commands/hubdb/__tests__/delete.test.js +0 -28
- package/commands/hubdb/__tests__/fetch.test.d.ts +0 -1
- package/commands/hubdb/__tests__/fetch.test.js +0 -28
- package/commands/hubdb/__tests__/list.test.d.ts +0 -1
- package/commands/hubdb/__tests__/list.test.js +0 -88
- package/commands/mcp/__tests__/setup.test.d.ts +0 -1
- package/commands/mcp/__tests__/setup.test.js +0 -26
- package/commands/mcp/__tests__/start.test.d.ts +0 -1
- package/commands/mcp/__tests__/start.test.js +0 -144
- package/commands/project/__tests__/add.test.d.ts +0 -1
- package/commands/project/__tests__/add.test.js +0 -107
- package/commands/project/__tests__/create.test.d.ts +0 -1
- package/commands/project/__tests__/create.test.js +0 -97
- package/commands/project/__tests__/deploy.test.d.ts +0 -1
- package/commands/project/__tests__/deploy.test.js +0 -307
- package/commands/project/__tests__/dev.test.d.ts +0 -1
- package/commands/project/__tests__/dev.test.js +0 -273
- package/commands/project/__tests__/devUnifiedFlow.test.d.ts +0 -1
- package/commands/project/__tests__/devUnifiedFlow.test.js +0 -434
- package/commands/project/__tests__/download.test.d.ts +0 -1
- package/commands/project/__tests__/download.test.js +0 -39
- package/commands/project/__tests__/installDeps.test.d.ts +0 -1
- package/commands/project/__tests__/installDeps.test.js +0 -140
- package/commands/project/__tests__/lint.test.d.ts +0 -1
- package/commands/project/__tests__/lint.test.js +0 -704
- package/commands/project/__tests__/list.test.d.ts +0 -1
- package/commands/project/__tests__/list.test.js +0 -31
- package/commands/project/__tests__/listBuilds.test.d.ts +0 -1
- package/commands/project/__tests__/listBuilds.test.js +0 -38
- package/commands/project/__tests__/logs.test.d.ts +0 -1
- package/commands/project/__tests__/logs.test.js +0 -202
- package/commands/project/__tests__/migrate.test.d.ts +0 -1
- package/commands/project/__tests__/migrate.test.js +0 -106
- package/commands/project/__tests__/open.test.d.ts +0 -1
- package/commands/project/__tests__/open.test.js +0 -39
- package/commands/project/__tests__/profile.test.d.ts +0 -1
- package/commands/project/__tests__/profile.test.js +0 -42
- package/commands/project/__tests__/updateDeps.test.d.ts +0 -1
- package/commands/project/__tests__/updateDeps.test.js +0 -140
- package/commands/project/__tests__/upload.test.d.ts +0 -1
- package/commands/project/__tests__/upload.test.js +0 -234
- package/commands/project/__tests__/validate.test.d.ts +0 -1
- package/commands/project/__tests__/validate.test.js +0 -381
- package/commands/project/__tests__/watch.test.d.ts +0 -1
- package/commands/project/__tests__/watch.test.js +0 -35
- package/commands/sandbox/__tests__/create.test.d.ts +0 -1
- package/commands/sandbox/__tests__/create.test.js +0 -245
- package/commands/sandbox/__tests__/delete.test.d.ts +0 -1
- package/commands/sandbox/__tests__/delete.test.js +0 -31
- package/commands/secret/__tests__/addSecret.test.d.ts +0 -1
- package/commands/secret/__tests__/addSecret.test.js +0 -162
- package/commands/secret/__tests__/deleteSecret.test.d.ts +0 -1
- package/commands/secret/__tests__/deleteSecret.test.js +0 -41
- package/commands/secret/__tests__/listSecret.test.d.ts +0 -1
- package/commands/secret/__tests__/listSecret.test.js +0 -29
- package/commands/secret/__tests__/updateSecret.test.d.ts +0 -1
- package/commands/secret/__tests__/updateSecret.test.js +0 -29
- package/commands/testAccount/__tests__/create.test.d.ts +0 -1
- package/commands/testAccount/__tests__/create.test.js +0 -106
- package/commands/testAccount/__tests__/createConfig.test.d.ts +0 -1
- package/commands/testAccount/__tests__/createConfig.test.js +0 -32
- package/commands/testAccount/__tests__/delete.test.d.ts +0 -1
- package/commands/testAccount/__tests__/delete.test.js +0 -29
- package/commands/testAccount/__tests__/importData.test.d.ts +0 -1
- package/commands/testAccount/__tests__/importData.test.js +0 -92
- package/lib/__tests__/CLIWebSocketServer.test.d.ts +0 -1
- package/lib/__tests__/CLIWebSocketServer.test.js +0 -252
- package/lib/__tests__/accountAuth.test.d.ts +0 -1
- package/lib/__tests__/accountAuth.test.js +0 -258
- package/lib/__tests__/accountTypes.test.d.ts +0 -1
- package/lib/__tests__/accountTypes.test.js +0 -98
- package/lib/__tests__/buildAccount.test.d.ts +0 -1
- package/lib/__tests__/buildAccount.test.js +0 -262
- package/lib/__tests__/cliUpgradeUtils.test.d.ts +0 -1
- package/lib/__tests__/cliUpgradeUtils.test.js +0 -131
- package/lib/__tests__/commandSuggestion.test.d.ts +0 -1
- package/lib/__tests__/commandSuggestion.test.js +0 -121
- package/lib/__tests__/commonOpts.test.d.ts +0 -1
- package/lib/__tests__/commonOpts.test.js +0 -80
- package/lib/__tests__/dependencyManagement.test.d.ts +0 -1
- package/lib/__tests__/dependencyManagement.test.js +0 -1067
- package/lib/__tests__/developerTestAccounts.test.d.ts +0 -1
- package/lib/__tests__/developerTestAccounts.test.js +0 -156
- package/lib/__tests__/hasFeature.test.d.ts +0 -1
- package/lib/__tests__/hasFeature.test.js +0 -167
- package/lib/__tests__/http.test.d.ts +0 -1
- package/lib/__tests__/http.test.js +0 -40
- package/lib/__tests__/importData.test.d.ts +0 -1
- package/lib/__tests__/importData.test.js +0 -98
- package/lib/__tests__/npmCli.test.d.ts +0 -1
- package/lib/__tests__/npmCli.test.js +0 -84
- package/lib/__tests__/oauth.test.d.ts +0 -1
- package/lib/__tests__/oauth.test.js +0 -109
- package/lib/__tests__/parsing.test.d.ts +0 -1
- package/lib/__tests__/parsing.test.js +0 -34
- package/lib/__tests__/polling.test.d.ts +0 -1
- package/lib/__tests__/polling.test.js +0 -76
- package/lib/__tests__/process.test.d.ts +0 -1
- package/lib/__tests__/process.test.js +0 -89
- package/lib/__tests__/sandboxSync.test.d.ts +0 -1
- package/lib/__tests__/sandboxSync.test.js +0 -147
- package/lib/__tests__/sandboxes.test.d.ts +0 -1
- package/lib/__tests__/sandboxes.test.js +0 -156
- package/lib/__tests__/serverlessLogs.test.d.ts +0 -1
- package/lib/__tests__/serverlessLogs.test.js +0 -163
- package/lib/__tests__/usageTracking.test.d.ts +0 -1
- package/lib/__tests__/usageTracking.test.js +0 -197
- package/lib/__tests__/validation.test.d.ts +0 -1
- package/lib/__tests__/validation.test.js +0 -143
- package/lib/__tests__/yargsUtils.test.d.ts +0 -1
- package/lib/__tests__/yargsUtils.test.js +0 -124
- package/lib/app/__tests__/migrate.test.d.ts +0 -1
- package/lib/app/__tests__/migrate.test.js +0 -638
- package/lib/doctor/__tests__/Diagnosis.test.d.ts +0 -1
- package/lib/doctor/__tests__/Diagnosis.test.js +0 -84
- package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.d.ts +0 -1
- package/lib/doctor/__tests__/DiagnosticInfoBuilder.test.js +0 -177
- package/lib/doctor/__tests__/Doctor.test.d.ts +0 -1
- package/lib/doctor/__tests__/Doctor.test.js +0 -560
- package/lib/errorHandlers/__tests__/index.test.d.ts +0 -1
- package/lib/errorHandlers/__tests__/index.test.js +0 -278
- package/lib/mcp/__tests__/setup.test.d.ts +0 -1
- package/lib/mcp/__tests__/setup.test.js +0 -523
- package/lib/middleware/__tests__/commandTargetingUtils.test.d.ts +0 -1
- package/lib/middleware/__tests__/commandTargetingUtils.test.js +0 -99
- package/lib/middleware/__tests__/configMiddleware.test.d.ts +0 -1
- package/lib/middleware/__tests__/configMiddleware.test.js +0 -118
- package/lib/middleware/__tests__/gitMiddleware.test.d.ts +0 -1
- package/lib/middleware/__tests__/gitMiddleware.test.js +0 -43
- package/lib/middleware/__tests__/requestMiddleware.test.d.ts +0 -1
- package/lib/middleware/__tests__/requestMiddleware.test.js +0 -15
- package/lib/middleware/__tests__/usageTrackingMiddleware.test.d.ts +0 -1
- package/lib/middleware/__tests__/usageTrackingMiddleware.test.js +0 -44
- package/lib/middleware/__tests__/yargsChecksMiddleware.test.d.ts +0 -1
- package/lib/middleware/__tests__/yargsChecksMiddleware.test.js +0 -39
- package/lib/projects/__tests__/AppDevModeInterface.test.d.ts +0 -1
- package/lib/projects/__tests__/AppDevModeInterface.test.js +0 -541
- package/lib/projects/__tests__/DevServerManager.test.d.ts +0 -1
- package/lib/projects/__tests__/DevServerManager.test.js +0 -185
- package/lib/projects/__tests__/DevSessionManager.test.d.ts +0 -1
- package/lib/projects/__tests__/DevSessionManager.test.js +0 -250
- package/lib/projects/__tests__/LocalDevProcess.test.d.ts +0 -1
- package/lib/projects/__tests__/LocalDevProcess.test.js +0 -481
- package/lib/projects/__tests__/LocalDevWebsocketServer.test.d.ts +0 -1
- package/lib/projects/__tests__/LocalDevWebsocketServer.test.js +0 -231
- package/lib/projects/__tests__/ProjectLogsManager.test.d.ts +0 -1
- package/lib/projects/__tests__/ProjectLogsManager.test.js +0 -302
- package/lib/projects/__tests__/UIExtensionsDevModeInterface.test.d.ts +0 -1
- package/lib/projects/__tests__/UIExtensionsDevModeInterface.test.js +0 -160
- package/lib/projects/__tests__/components.test.d.ts +0 -1
- package/lib/projects/__tests__/components.test.js +0 -426
- package/lib/projects/__tests__/deploy.test.d.ts +0 -1
- package/lib/projects/__tests__/deploy.test.js +0 -231
- package/lib/projects/__tests__/localDevProjectHelpers.test.d.ts +0 -1
- package/lib/projects/__tests__/localDevProjectHelpers.test.js +0 -120
- package/lib/projects/__tests__/platformVersion.test.d.ts +0 -1
- package/lib/projects/__tests__/platformVersion.test.js +0 -63
- package/lib/projects/__tests__/pollProjectBuildAndDeploy.test.d.ts +0 -1
- package/lib/projects/__tests__/pollProjectBuildAndDeploy.test.js +0 -328
- package/lib/projects/__tests__/projectProfiles.test.d.ts +0 -1
- package/lib/projects/__tests__/projectProfiles.test.js +0 -441
- package/lib/projects/__tests__/projects.test.d.ts +0 -1
- package/lib/projects/__tests__/projects.test.js +0 -58
- package/lib/projects/__tests__/structure.test.d.ts +0 -1
- package/lib/projects/__tests__/structure.test.js +0 -210
- package/lib/projects/__tests__/uieLinting.test.d.ts +0 -1
- package/lib/projects/__tests__/uieLinting.test.js +0 -631
- package/lib/projects/__tests__/upload.test.d.ts +0 -1
- package/lib/projects/__tests__/upload.test.js +0 -183
- package/lib/projects/add/__tests__/legacyAddComponent.test.d.ts +0 -1
- package/lib/projects/add/__tests__/legacyAddComponent.test.js +0 -245
- package/lib/projects/add/__tests__/v2AddComponent.test.d.ts +0 -1
- package/lib/projects/add/__tests__/v2AddComponent.test.js +0 -343
- package/lib/projects/create/__tests__/legacy.test.d.ts +0 -1
- package/lib/projects/create/__tests__/legacy.test.js +0 -72
- package/lib/projects/create/__tests__/v2.test.d.ts +0 -1
- package/lib/projects/create/__tests__/v2.test.js +0 -257
- package/lib/projects/platformVersion.d.ts +0 -9
- package/lib/projects/platformVersion.js +0 -39
- package/lib/prompts/__tests__/createDeveloperTestAccountConfigPrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/createDeveloperTestAccountConfigPrompt.test.js +0 -157
- package/lib/prompts/__tests__/createFunctionPrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/createFunctionPrompt.test.js +0 -129
- package/lib/prompts/__tests__/createModulePrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/createModulePrompt.test.js +0 -187
- package/lib/prompts/__tests__/createTemplatePrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/createTemplatePrompt.test.js +0 -102
- package/lib/prompts/__tests__/downloadProjectPrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/downloadProjectPrompt.test.js +0 -31
- package/lib/prompts/__tests__/projectAddPrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/projectAddPrompt.test.js +0 -143
- package/lib/prompts/__tests__/projectsLogsPrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/projectsLogsPrompt.test.js +0 -37
- package/lib/prompts/__tests__/selectProjectTemplatePrompt.test.d.ts +0 -1
- package/lib/prompts/__tests__/selectProjectTemplatePrompt.test.js +0 -160
- package/lib/sandboxSync.d.ts +0 -4
- package/lib/sandboxSync.js +0 -102
- package/lib/theme/__tests__/migrate.test.d.ts +0 -1
- package/lib/theme/__tests__/migrate.test.js +0 -256
- package/lib/ui/__tests__/SpinniesManager.test.d.ts +0 -1
- package/lib/ui/__tests__/SpinniesManager.test.js +0 -488
- package/lib/ui/__tests__/removeAnsiCodes.test.d.ts +0 -1
- package/lib/ui/__tests__/removeAnsiCodes.test.js +0 -84
- package/mcp-server/tools/cms/__tests__/HsCreateFunctionTool.test.d.ts +0 -1
- package/mcp-server/tools/cms/__tests__/HsCreateFunctionTool.test.js +0 -254
- package/mcp-server/tools/cms/__tests__/HsCreateModuleTool.test.d.ts +0 -1
- package/mcp-server/tools/cms/__tests__/HsCreateModuleTool.test.js +0 -227
- package/mcp-server/tools/cms/__tests__/HsCreateTemplateTool.test.d.ts +0 -1
- package/mcp-server/tools/cms/__tests__/HsCreateTemplateTool.test.js +0 -208
- package/mcp-server/tools/cms/__tests__/HsFunctionLogsTool.test.d.ts +0 -1
- package/mcp-server/tools/cms/__tests__/HsFunctionLogsTool.test.js +0 -186
- package/mcp-server/tools/cms/__tests__/HsListFunctionsTool.test.d.ts +0 -1
- package/mcp-server/tools/cms/__tests__/HsListFunctionsTool.test.js +0 -124
- package/mcp-server/tools/cms/__tests__/HsListTool.test.d.ts +0 -1
- package/mcp-server/tools/cms/__tests__/HsListTool.test.js +0 -124
- package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/AddFeatureToProjectTool.test.js +0 -157
- package/mcp-server/tools/project/__tests__/CreateProjectTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/CreateProjectTool.test.js +0 -132
- package/mcp-server/tools/project/__tests__/CreateTestAccountTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/CreateTestAccountTool.test.js +0 -461
- package/mcp-server/tools/project/__tests__/DeployProjectTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/DeployProjectTool.test.js +0 -125
- package/mcp-server/tools/project/__tests__/DocFetchTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/DocFetchTool.test.js +0 -125
- package/mcp-server/tools/project/__tests__/DocsSearchTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/DocsSearchTool.test.js +0 -210
- package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.js +0 -146
- package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.js +0 -124
- package/mcp-server/tools/project/__tests__/GetBuildLogsTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/GetBuildLogsTool.test.js +0 -307
- package/mcp-server/tools/project/__tests__/GetBuildStatusTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/GetBuildStatusTool.test.js +0 -242
- package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/GetConfigValuesTool.test.js +0 -209
- package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/GuidedWalkthroughTool.test.js +0 -158
- package/mcp-server/tools/project/__tests__/UploadProjectTools.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/UploadProjectTools.test.js +0 -187
- package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.d.ts +0 -1
- package/mcp-server/tools/project/__tests__/ValidateProjectTool.test.js +0 -118
- package/mcp-server/utils/__tests__/command.test.d.ts +0 -1
- package/mcp-server/utils/__tests__/command.test.js +0 -275
- package/mcp-server/utils/__tests__/content.test.d.ts +0 -1
- package/mcp-server/utils/__tests__/content.test.js +0 -164
- package/mcp-server/utils/__tests__/feedbackTracking.test.d.ts +0 -1
- package/mcp-server/utils/__tests__/feedbackTracking.test.js +0 -69
|
@@ -0,0 +1,411 @@
|
|
|
1
|
+
import fs from 'fs-extra';
|
|
2
|
+
import path from 'path';
|
|
3
|
+
import crypto from 'crypto';
|
|
4
|
+
import { shouldIgnoreFile } from '@hubspot/local-dev-lib/ignoreRules';
|
|
5
|
+
import { getPackableFiles, } from '@hubspot/project-parsing-lib/workspaces';
|
|
6
|
+
import { uiLogger } from '../ui/logger.js';
|
|
7
|
+
import { lib } from '../../lang/en.js';
|
|
8
|
+
const FILE_PROTOCOL_PREFIX = 'file:';
|
|
9
|
+
const LINK_PROTOCOL_PREFIX = 'link:';
|
|
10
|
+
const KIND_DIRECTORY = 'directory';
|
|
11
|
+
const KIND_TARBALL = 'tarball';
|
|
12
|
+
/**
|
|
13
|
+
* Generates a short hash of the input string for use in workspace paths.
|
|
14
|
+
* Uses SHA256 truncated to 8 hex characters (4 billion possibilities).
|
|
15
|
+
*/
|
|
16
|
+
export function shortHash(input) {
|
|
17
|
+
return crypto.createHash('sha256').update(input).digest('hex').slice(0, 8);
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Converts native path separators to POSIX forward slashes.
|
|
21
|
+
*
|
|
22
|
+
* Zip entry names and npm workspace globs are POSIX-only. On Windows,
|
|
23
|
+
* `path.relative` returns backslash-separated paths; archiver normalizes
|
|
24
|
+
* its appended entry names to forward slashes but its filter callback
|
|
25
|
+
* receives forward-slashed names too. Without this normalization, lookups
|
|
26
|
+
* in our exclusion Sets miss on Windows and a file gets archived twice.
|
|
27
|
+
*/
|
|
28
|
+
export function toPosixPath(p) {
|
|
29
|
+
if (path.sep === path.posix.sep) {
|
|
30
|
+
return p;
|
|
31
|
+
}
|
|
32
|
+
return p.replaceAll(path.sep, path.posix.sep);
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Strips the longest matching tarball extension (.tar.gz, .tgz, .tar)
|
|
36
|
+
* from a file basename. Returns the input unchanged if no extension matches.
|
|
37
|
+
*/
|
|
38
|
+
function stripTarballExtension(basename) {
|
|
39
|
+
const lower = basename.toLowerCase();
|
|
40
|
+
for (const ext of ['.tar.gz', '.tgz', '.tar']) {
|
|
41
|
+
if (lower.endsWith(ext)) {
|
|
42
|
+
return basename.slice(0, basename.length - ext.length);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
return basename;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Determines the archive path for an external workspace or file: dependency.
|
|
49
|
+
*
|
|
50
|
+
* For directories, produces `_workspaces/<basename>-<hash>`.
|
|
51
|
+
* For tarballs, produces `_workspaces/<basename-no-ext>-<hash>/<original-basename>`,
|
|
52
|
+
* so the rewritten package.json reference still ends in the original filename.
|
|
53
|
+
*
|
|
54
|
+
* The hash prevents collisions between different paths with the same basename.
|
|
55
|
+
*/
|
|
56
|
+
export function computeExternalArchivePath(absolutePath, kind = KIND_DIRECTORY) {
|
|
57
|
+
const resolved = path.resolve(absolutePath);
|
|
58
|
+
const name = path.basename(resolved);
|
|
59
|
+
if (kind === KIND_TARBALL) {
|
|
60
|
+
const nameNoExt = stripTarballExtension(name);
|
|
61
|
+
return path.posix.join('_workspaces', `${nameNoExt}-${shortHash(resolved)}`, name);
|
|
62
|
+
}
|
|
63
|
+
return path.posix.join('_workspaces', `${name}-${shortHash(resolved)}`);
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Returns true if dir is inside srcDir (i.e. it will already be included
|
|
67
|
+
* in the archive from the srcDir walk and must not be copied again).
|
|
68
|
+
*/
|
|
69
|
+
function isInsideSrcDir(dir, srcDir) {
|
|
70
|
+
const rel = path.relative(path.resolve(srcDir), path.resolve(dir));
|
|
71
|
+
return !rel.startsWith('..') && !path.isAbsolute(rel);
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Creates a file filter function for workspace archiving.
|
|
75
|
+
* Filters files based on packable files list and ignore rules.
|
|
76
|
+
*/
|
|
77
|
+
function createWorkspaceFileFilter(packableFiles) {
|
|
78
|
+
return (file) => {
|
|
79
|
+
if (packableFiles.size > 0 && !packableFiles.has(file.name)) {
|
|
80
|
+
uiLogger.debug(lib.projectUpload.handleProjectUpload.fileFiltered(file.name));
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
const ignored = shouldIgnoreFile(file.name, true);
|
|
84
|
+
if (ignored) {
|
|
85
|
+
uiLogger.debug(lib.projectUpload.handleProjectUpload.fileFiltered(file.name));
|
|
86
|
+
return false;
|
|
87
|
+
}
|
|
88
|
+
return file;
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Archives workspace directories and returns mapping information.
|
|
93
|
+
*
|
|
94
|
+
* Internal workspaces (inside srcDir) are not archived — they are already
|
|
95
|
+
* included via the srcDir walk. Their relative paths (from the package.json
|
|
96
|
+
* directory to the workspace directory) are stored directly in the entries.
|
|
97
|
+
*
|
|
98
|
+
* External workspaces (outside srcDir) are copied to `_workspaces/<name>-<hash>`
|
|
99
|
+
* and their relative archive paths (e.g. `../_workspaces/<name>-<hash>`) are stored.
|
|
100
|
+
*/
|
|
101
|
+
async function archiveWorkspaceDirectories(archive, srcDir, workspaceMappings) {
|
|
102
|
+
const externalArchivePaths = new Map(); // resolvedDir -> archivePath
|
|
103
|
+
const archivePathToDir = new Map(); // archivePath -> resolvedDir (collision detection)
|
|
104
|
+
const packageWorkspaceEntries = new Map();
|
|
105
|
+
const externalsToArchive = [];
|
|
106
|
+
for (const mapping of workspaceMappings) {
|
|
107
|
+
const { workspaceDir, sourcePackageJsonPath } = mapping;
|
|
108
|
+
if (!packageWorkspaceEntries.has(sourcePackageJsonPath)) {
|
|
109
|
+
packageWorkspaceEntries.set(sourcePackageJsonPath, []);
|
|
110
|
+
}
|
|
111
|
+
if (isInsideSrcDir(workspaceDir, srcDir)) {
|
|
112
|
+
// Internal: already in archive from srcDir walk.
|
|
113
|
+
// Store the relative path from the package.json directory so npm can resolve it.
|
|
114
|
+
const relPath = toPosixPath(path.relative(path.dirname(sourcePackageJsonPath), path.resolve(workspaceDir)));
|
|
115
|
+
packageWorkspaceEntries.get(sourcePackageJsonPath).push(relPath);
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
// External: archive to _workspaces/<name>-<hash>.
|
|
119
|
+
const archivePath = computeExternalArchivePath(workspaceDir);
|
|
120
|
+
const resolvedDir = path.resolve(workspaceDir);
|
|
121
|
+
// Detect hash collisions (different dirs mapping to the same archive path)
|
|
122
|
+
const existing = archivePathToDir.get(archivePath);
|
|
123
|
+
if (existing && existing !== resolvedDir) {
|
|
124
|
+
throw new Error(lib.projectUpload.handleProjectUpload.workspaceCollision(archivePath, workspaceDir, existing));
|
|
125
|
+
}
|
|
126
|
+
if (!externalArchivePaths.has(resolvedDir)) {
|
|
127
|
+
externalArchivePaths.set(resolvedDir, archivePath);
|
|
128
|
+
archivePathToDir.set(archivePath, resolvedDir);
|
|
129
|
+
externalsToArchive.push({ dir: workspaceDir, archivePath });
|
|
130
|
+
}
|
|
131
|
+
const relPkgJsonDir = path.relative(srcDir, path.dirname(sourcePackageJsonPath));
|
|
132
|
+
const relativeEntry = toPosixPath(path.relative(relPkgJsonDir, archivePath));
|
|
133
|
+
packageWorkspaceEntries.get(sourcePackageJsonPath).push(relativeEntry);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
// Fetch packable files in parallel (I/O optimization)
|
|
137
|
+
const withPackableFiles = await Promise.all(externalsToArchive.map(async (item) => ({
|
|
138
|
+
...item,
|
|
139
|
+
packableFiles: await getPackableFiles(item.dir),
|
|
140
|
+
})));
|
|
141
|
+
// Archive directories sequentially (archiver requires sequential operations)
|
|
142
|
+
for (const { dir, archivePath, packableFiles } of withPackableFiles) {
|
|
143
|
+
uiLogger.log(lib.projectUpload.handleProjectUpload.workspaceIncluded(dir, archivePath));
|
|
144
|
+
archive.directory(dir, archivePath, createWorkspaceFileFilter(packableFiles));
|
|
145
|
+
}
|
|
146
|
+
return { externalArchivePaths, packageWorkspaceEntries };
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Archives file: and link: dependencies and returns mapping information.
|
|
150
|
+
*
|
|
151
|
+
* Internal dependencies (inside srcDir) are skipped — their original
|
|
152
|
+
* references in package.json remain valid after upload.
|
|
153
|
+
*
|
|
154
|
+
* External directory dependencies are archived to `_workspaces/<name>-<hash>`.
|
|
155
|
+
* External tarball dependencies are archived to
|
|
156
|
+
* `_workspaces/<name-no-ext>-<hash>/<original-basename>` so the rewritten
|
|
157
|
+
* reference still ends in the original filename.
|
|
158
|
+
*/
|
|
159
|
+
async function archiveFileDependencies(archive, srcDir, fileDependencyMappings, externalArchivePaths) {
|
|
160
|
+
const packageFileDeps = new Map();
|
|
161
|
+
const toArchive = [];
|
|
162
|
+
for (const mapping of fileDependencyMappings) {
|
|
163
|
+
const { packageName, localPath, sourcePackageJsonPath, kind, protocol } = mapping;
|
|
164
|
+
if (isInsideSrcDir(localPath, srcDir)) {
|
|
165
|
+
continue;
|
|
166
|
+
}
|
|
167
|
+
const archivePath = computeExternalArchivePath(localPath, kind);
|
|
168
|
+
const resolvedPath = path.resolve(localPath);
|
|
169
|
+
if (!packageFileDeps.has(sourcePackageJsonPath)) {
|
|
170
|
+
packageFileDeps.set(sourcePackageJsonPath, new Map());
|
|
171
|
+
}
|
|
172
|
+
const relPkgJsonDir = path.relative(srcDir, path.dirname(sourcePackageJsonPath));
|
|
173
|
+
const relativeArchivePath = toPosixPath(path.relative(relPkgJsonDir, archivePath));
|
|
174
|
+
packageFileDeps
|
|
175
|
+
.get(sourcePackageJsonPath)
|
|
176
|
+
.set(packageName, { archivePath: relativeArchivePath, protocol });
|
|
177
|
+
if (!externalArchivePaths.has(resolvedPath)) {
|
|
178
|
+
externalArchivePaths.set(resolvedPath, archivePath);
|
|
179
|
+
toArchive.push({ localPath, archivePath, packageName, kind });
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
const directoryItems = toArchive.filter(item => item.kind === KIND_DIRECTORY);
|
|
183
|
+
const tarballItems = toArchive.filter(item => item.kind === KIND_TARBALL);
|
|
184
|
+
// getPackableFiles only applies to directory deps; tarballs are a single file.
|
|
185
|
+
const directoriesWithPackableFiles = await Promise.all(directoryItems.map(async (item) => ({
|
|
186
|
+
...item,
|
|
187
|
+
packableFiles: await getPackableFiles(item.localPath),
|
|
188
|
+
})));
|
|
189
|
+
for (const { localPath, archivePath, packageName, packableFiles, } of directoriesWithPackableFiles) {
|
|
190
|
+
uiLogger.log(lib.projectUpload.handleProjectUpload.fileDependencyIncluded(packageName, localPath, archivePath));
|
|
191
|
+
archive.directory(localPath, archivePath, createWorkspaceFileFilter(packableFiles));
|
|
192
|
+
}
|
|
193
|
+
for (const { localPath, archivePath, packageName } of tarballItems) {
|
|
194
|
+
uiLogger.log(lib.projectUpload.handleProjectUpload.fileDependencyIncluded(packageName, localPath, archivePath));
|
|
195
|
+
archive.file(localPath, { name: archivePath });
|
|
196
|
+
}
|
|
197
|
+
return packageFileDeps;
|
|
198
|
+
}
|
|
199
|
+
/**
|
|
200
|
+
* Updates package.json files in the archive to reflect new workspace and file: dependency paths.
|
|
201
|
+
*
|
|
202
|
+
* Workspace entries in packageWorkspaces are already in final form:
|
|
203
|
+
* - Internal workspaces: relative paths (e.g. "../packages/utils")
|
|
204
|
+
* - External workspaces: relative paths (e.g. "../_workspaces/logger-abc")
|
|
205
|
+
*
|
|
206
|
+
* Only external file: dependencies appear in packageFileDeps; internal ones
|
|
207
|
+
* keep their original file: references and are left untouched.
|
|
208
|
+
*/
|
|
209
|
+
export async function updatePackageJsonInArchive(archive, srcDir, packageWorkspaces, packageFileDeps) {
|
|
210
|
+
// Collect all package.json paths that need updating
|
|
211
|
+
const allPackageJsonPaths = new Set([
|
|
212
|
+
...packageWorkspaces.keys(),
|
|
213
|
+
...packageFileDeps.keys(),
|
|
214
|
+
]);
|
|
215
|
+
for (const packageJsonPath of allPackageJsonPaths) {
|
|
216
|
+
if (!fs.existsSync(packageJsonPath)) {
|
|
217
|
+
continue;
|
|
218
|
+
}
|
|
219
|
+
const relativePackageJsonPath = toPosixPath(path.relative(srcDir, packageJsonPath));
|
|
220
|
+
let rawContent;
|
|
221
|
+
try {
|
|
222
|
+
rawContent = fs.readFileSync(packageJsonPath, 'utf8');
|
|
223
|
+
}
|
|
224
|
+
catch {
|
|
225
|
+
continue;
|
|
226
|
+
}
|
|
227
|
+
let packageJson;
|
|
228
|
+
try {
|
|
229
|
+
packageJson = JSON.parse(rawContent);
|
|
230
|
+
}
|
|
231
|
+
catch (e) {
|
|
232
|
+
uiLogger.warn(lib.projectUpload.handleProjectUpload.malformedPackageJson(packageJsonPath, e instanceof Error ? e.message : String(e)));
|
|
233
|
+
archive.append(rawContent, { name: relativePackageJsonPath });
|
|
234
|
+
continue;
|
|
235
|
+
}
|
|
236
|
+
let modified = false;
|
|
237
|
+
// Update workspaces field — entries are already in their final form
|
|
238
|
+
const workspaceEntries = packageWorkspaces.get(packageJsonPath);
|
|
239
|
+
if (workspaceEntries && packageJson.workspaces) {
|
|
240
|
+
packageJson.workspaces = workspaceEntries;
|
|
241
|
+
modified = true;
|
|
242
|
+
uiLogger.debug(lib.projectUpload.handleProjectUpload.updatingPackageJsonWorkspaces(relativePackageJsonPath));
|
|
243
|
+
uiLogger.debug(lib.projectUpload.handleProjectUpload.updatedWorkspaces(workspaceEntries.join(', ')));
|
|
244
|
+
}
|
|
245
|
+
// Update external file: and link: dependencies; internal ones are left untouched.
|
|
246
|
+
// The protocol prefix (file: vs link:) is preserved from the original spec.
|
|
247
|
+
const fileDeps = packageFileDeps.get(packageJsonPath);
|
|
248
|
+
if (fileDeps && fileDeps.size > 0 && packageJson.dependencies) {
|
|
249
|
+
for (const [packageName, { archivePath, protocol },] of fileDeps.entries()) {
|
|
250
|
+
const current = packageJson.dependencies[packageName];
|
|
251
|
+
if (typeof current === 'string' &&
|
|
252
|
+
(current.startsWith(FILE_PROTOCOL_PREFIX) ||
|
|
253
|
+
current.startsWith(LINK_PROTOCOL_PREFIX))) {
|
|
254
|
+
const newValue = `${protocol}:${archivePath}`;
|
|
255
|
+
packageJson.dependencies[packageName] = newValue;
|
|
256
|
+
modified = true;
|
|
257
|
+
uiLogger.debug(lib.projectUpload.handleProjectUpload.updatedFileDependency(packageName, newValue));
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
archive.append(modified ? JSON.stringify(packageJson, null, 2) : rawContent, { name: relativePackageJsonPath });
|
|
262
|
+
}
|
|
263
|
+
// Ensure all append operations are queued before finalize is called
|
|
264
|
+
// Use setImmediate to yield control and let archiver process the queue
|
|
265
|
+
await new Promise(resolve => setImmediate(resolve));
|
|
266
|
+
}
|
|
267
|
+
export function rewriteLockfileForExternalDeps(lockfileContent, pathMappings) {
|
|
268
|
+
if (pathMappings.length === 0) {
|
|
269
|
+
return lockfileContent;
|
|
270
|
+
}
|
|
271
|
+
const packages = lockfileContent.packages;
|
|
272
|
+
if (!packages) {
|
|
273
|
+
return lockfileContent;
|
|
274
|
+
}
|
|
275
|
+
const newPackages = {};
|
|
276
|
+
for (const [key, value] of Object.entries(packages)) {
|
|
277
|
+
const mapping = pathMappings.find(m => m.oldPath === key);
|
|
278
|
+
newPackages[mapping ? mapping.newPath : key] = value;
|
|
279
|
+
}
|
|
280
|
+
for (const [key, value] of Object.entries(newPackages)) {
|
|
281
|
+
if (key.startsWith('node_modules/') &&
|
|
282
|
+
typeof value === 'object' &&
|
|
283
|
+
value !== null) {
|
|
284
|
+
const entry = value;
|
|
285
|
+
if (typeof entry.resolved !== 'string')
|
|
286
|
+
continue;
|
|
287
|
+
// Symlink entries (directory deps with link:true) store resolved as a
|
|
288
|
+
// bare relative path. Tarball entries store resolved as a "file:" URL.
|
|
289
|
+
const resolved = entry.resolved;
|
|
290
|
+
const isFileUrl = resolved.startsWith(FILE_PROTOCOL_PREFIX);
|
|
291
|
+
const resolvedPath = isFileUrl
|
|
292
|
+
? resolved.slice(FILE_PROTOCOL_PREFIX.length)
|
|
293
|
+
: resolved;
|
|
294
|
+
const mapping = pathMappings.find(m => m.oldPath === resolvedPath);
|
|
295
|
+
if (mapping) {
|
|
296
|
+
newPackages[key] = {
|
|
297
|
+
...entry,
|
|
298
|
+
resolved: isFileUrl
|
|
299
|
+
? `${FILE_PROTOCOL_PREFIX}${mapping.newPath}`
|
|
300
|
+
: mapping.newPath,
|
|
301
|
+
};
|
|
302
|
+
}
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
const rootEntry = newPackages[''];
|
|
306
|
+
if (rootEntry && typeof rootEntry === 'object' && rootEntry !== null) {
|
|
307
|
+
const root = rootEntry;
|
|
308
|
+
if (Array.isArray(root.workspaces)) {
|
|
309
|
+
newPackages[''] = {
|
|
310
|
+
...root,
|
|
311
|
+
workspaces: root.workspaces.map((ws) => {
|
|
312
|
+
if (typeof ws !== 'string')
|
|
313
|
+
return ws;
|
|
314
|
+
const mapping = pathMappings.find(m => m.oldPath === ws);
|
|
315
|
+
return mapping ? mapping.newPath : ws;
|
|
316
|
+
}),
|
|
317
|
+
};
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
return { ...lockfileContent, packages: newPackages };
|
|
321
|
+
}
|
|
322
|
+
export function getPackageJsonPathsToUpdate(srcDir, workspaceMappings, fileDependencyMappings) {
|
|
323
|
+
const paths = new Set();
|
|
324
|
+
for (const { sourcePackageJsonPath } of workspaceMappings) {
|
|
325
|
+
paths.add(toPosixPath(path.relative(srcDir, sourcePackageJsonPath)));
|
|
326
|
+
}
|
|
327
|
+
for (const { localPath, sourcePackageJsonPath } of fileDependencyMappings) {
|
|
328
|
+
if (!isInsideSrcDir(localPath, srcDir)) {
|
|
329
|
+
paths.add(toPosixPath(path.relative(srcDir, sourcePackageJsonPath)));
|
|
330
|
+
}
|
|
331
|
+
}
|
|
332
|
+
return paths;
|
|
333
|
+
}
|
|
334
|
+
function getDirsWithExternalDeps(srcDir, workspaceMappings, fileDependencyMappings) {
|
|
335
|
+
const dirs = new Set();
|
|
336
|
+
for (const { workspaceDir, sourcePackageJsonPath } of workspaceMappings) {
|
|
337
|
+
if (!isInsideSrcDir(workspaceDir, srcDir)) {
|
|
338
|
+
dirs.add(path.dirname(sourcePackageJsonPath));
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
for (const { localPath, sourcePackageJsonPath } of fileDependencyMappings) {
|
|
342
|
+
if (!isInsideSrcDir(localPath, srcDir)) {
|
|
343
|
+
dirs.add(path.dirname(sourcePackageJsonPath));
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
return dirs;
|
|
347
|
+
}
|
|
348
|
+
export function getLockfilePathsToUpdate(srcDir, workspaceMappings, fileDependencyMappings) {
|
|
349
|
+
const dirsWithExternalDeps = getDirsWithExternalDeps(srcDir, workspaceMappings, fileDependencyMappings);
|
|
350
|
+
const paths = new Set();
|
|
351
|
+
for (const dir of dirsWithExternalDeps) {
|
|
352
|
+
const lockfilePath = path.join(dir, 'package-lock.json');
|
|
353
|
+
if (fs.existsSync(lockfilePath)) {
|
|
354
|
+
paths.add(toPosixPath(path.relative(srcDir, lockfilePath)));
|
|
355
|
+
}
|
|
356
|
+
}
|
|
357
|
+
return paths;
|
|
358
|
+
}
|
|
359
|
+
async function rewriteLockfilesInArchive(archive, srcDir, externalArchivePaths, dirsWithExternalDeps) {
|
|
360
|
+
if (externalArchivePaths.size === 0)
|
|
361
|
+
return;
|
|
362
|
+
for (const dir of dirsWithExternalDeps) {
|
|
363
|
+
const lockfilePath = path.join(dir, 'package-lock.json');
|
|
364
|
+
if (!fs.existsSync(lockfilePath))
|
|
365
|
+
continue;
|
|
366
|
+
let rawContent;
|
|
367
|
+
try {
|
|
368
|
+
rawContent = fs.readFileSync(lockfilePath, 'utf8');
|
|
369
|
+
}
|
|
370
|
+
catch {
|
|
371
|
+
continue;
|
|
372
|
+
}
|
|
373
|
+
let lockfileContent;
|
|
374
|
+
try {
|
|
375
|
+
lockfileContent = JSON.parse(rawContent);
|
|
376
|
+
}
|
|
377
|
+
catch {
|
|
378
|
+
continue;
|
|
379
|
+
}
|
|
380
|
+
const pathMappings = [];
|
|
381
|
+
for (const [absoluteExternalPath, archivePath] of externalArchivePaths) {
|
|
382
|
+
pathMappings.push({
|
|
383
|
+
oldPath: toPosixPath(path.relative(dir, absoluteExternalPath)),
|
|
384
|
+
newPath: toPosixPath(path.relative(dir, path.join(srcDir, archivePath))),
|
|
385
|
+
});
|
|
386
|
+
}
|
|
387
|
+
const rewritten = rewriteLockfileForExternalDeps(lockfileContent, pathMappings);
|
|
388
|
+
const relativeLockfilePath = toPosixPath(path.relative(srcDir, lockfilePath));
|
|
389
|
+
uiLogger.debug(lib.projectUpload.handleProjectUpload.updatingLockfile(relativeLockfilePath));
|
|
390
|
+
archive.append(JSON.stringify(rewritten, null, 2), {
|
|
391
|
+
name: relativeLockfilePath,
|
|
392
|
+
});
|
|
393
|
+
}
|
|
394
|
+
await new Promise(resolve => setImmediate(resolve));
|
|
395
|
+
}
|
|
396
|
+
/**
|
|
397
|
+
* Main orchestration function that handles archiving of workspaces and file dependencies.
|
|
398
|
+
* This is the clean integration point for upload.ts.
|
|
399
|
+
*/
|
|
400
|
+
export async function archiveWorkspacesAndDependencies(archive, srcDir, workspaceMappings, fileDependencyMappings) {
|
|
401
|
+
// Archive workspace directories (internal ones are skipped, externals are copied)
|
|
402
|
+
const { externalArchivePaths, packageWorkspaceEntries } = await archiveWorkspaceDirectories(archive, srcDir, workspaceMappings);
|
|
403
|
+
// Archive external file: dependencies (internals are skipped)
|
|
404
|
+
const packageFileDeps = await archiveFileDependencies(archive, srcDir, fileDependencyMappings, externalArchivePaths);
|
|
405
|
+
// Update package.json files with new paths
|
|
406
|
+
await updatePackageJsonInArchive(archive, srcDir, packageWorkspaceEntries, packageFileDeps);
|
|
407
|
+
// Rewrite lock files to point to archive paths for external deps
|
|
408
|
+
const dirsWithExternalDeps = getDirsWithExternalDeps(srcDir, workspaceMappings, fileDependencyMappings);
|
|
409
|
+
await rewriteLockfilesInArchive(archive, srcDir, externalArchivePaths, dirsWithExternalDeps);
|
|
410
|
+
return { packageWorkspaces: packageWorkspaceEntries, packageFileDeps };
|
|
411
|
+
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { promptUser } from './promptUtils.js';
|
|
2
2
|
import { lib } from '../../lang/en.js';
|
|
3
|
+
import { isPromptExitError } from '../errors/PromptExitError.js';
|
|
3
4
|
function getSampleTypesPrompt(choices) {
|
|
4
5
|
return {
|
|
5
6
|
type: 'rawlist',
|
|
@@ -53,6 +54,9 @@ export async function createApiSamplePrompt(samplesConfig) {
|
|
|
53
54
|
};
|
|
54
55
|
}
|
|
55
56
|
catch (e) {
|
|
57
|
+
if (isPromptExitError(e)) {
|
|
58
|
+
throw e;
|
|
59
|
+
}
|
|
56
60
|
return {};
|
|
57
61
|
}
|
|
58
62
|
}
|
|
@@ -2,21 +2,22 @@ import { promptUser } from './promptUtils.js';
|
|
|
2
2
|
import { getConfigAccountIfExists } from '@hubspot/local-dev-lib/config';
|
|
3
3
|
import { fetchProjects } from '@hubspot/local-dev-lib/api/projects';
|
|
4
4
|
import { logError, ApiErrorContext } from '../errorHandlers/index.js';
|
|
5
|
-
import { uiLogger } from '../ui/logger.js';
|
|
6
|
-
import { EXIT_CODES } from '../enums/exitCodes.js';
|
|
7
5
|
import { lib } from '../../lang/en.js';
|
|
6
|
+
import { PromptExitError } from '../errors/PromptExitError.js';
|
|
7
|
+
import { EXIT_CODES } from '../enums/exitCodes.js';
|
|
8
|
+
import { uiLogger } from '../ui/logger.js';
|
|
8
9
|
async function createProjectsList(accountId) {
|
|
9
|
-
|
|
10
|
-
if (accountId) {
|
|
11
|
-
const { data: projects } = await fetchProjects(accountId);
|
|
12
|
-
return projects.results;
|
|
13
|
-
}
|
|
10
|
+
if (!accountId) {
|
|
14
11
|
uiLogger.error(lib.prompts.downloadProjectPrompt.errors.accountIdRequired);
|
|
15
|
-
|
|
12
|
+
throw new PromptExitError(lib.prompts.downloadProjectPrompt.errors.accountIdRequired, EXIT_CODES.ERROR);
|
|
13
|
+
}
|
|
14
|
+
try {
|
|
15
|
+
const { data: projects } = await fetchProjects(accountId);
|
|
16
|
+
return projects.results;
|
|
16
17
|
}
|
|
17
18
|
catch (e) {
|
|
18
|
-
logError(e,
|
|
19
|
-
|
|
19
|
+
logError(e, new ApiErrorContext({ accountId }));
|
|
20
|
+
throw new PromptExitError('Failed to fetch projects', EXIT_CODES.ERROR);
|
|
20
21
|
}
|
|
21
22
|
}
|
|
22
23
|
export async function downloadProjectPrompt(promptOptions) {
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import open from 'open';
|
|
2
2
|
import { promptUser } from './promptUtils.js';
|
|
3
|
-
import { EXIT_CODES } from '../enums/exitCodes.js';
|
|
4
3
|
import { lib } from '../../lang/en.js';
|
|
5
4
|
import { uiLogger } from '../ui/logger.js';
|
|
5
|
+
import { PromptExitError } from '../errors/PromptExitError.js';
|
|
6
|
+
import { EXIT_CODES } from '../enums/exitCodes.js';
|
|
6
7
|
export async function installAppBrowserPrompt(installUrl, isReinstall = false) {
|
|
7
8
|
uiLogger.log('');
|
|
8
9
|
if (isReinstall) {
|
|
@@ -20,7 +21,7 @@ export async function installAppBrowserPrompt(installUrl, isReinstall = false) {
|
|
|
20
21
|
});
|
|
21
22
|
if (!isReinstall && !shouldOpenBrowser) {
|
|
22
23
|
uiLogger.log(lib.prompts.installAppPrompt.decline);
|
|
23
|
-
|
|
24
|
+
throw new PromptExitError(lib.prompts.installAppPrompt.decline, EXIT_CODES.SUCCESS);
|
|
24
25
|
}
|
|
25
26
|
else if (!shouldOpenBrowser) {
|
|
26
27
|
return;
|
|
@@ -17,13 +17,10 @@ type ScopesPromptResponse = {
|
|
|
17
17
|
scopes: string[];
|
|
18
18
|
};
|
|
19
19
|
export type OauthPromptResponse = AccountNamePromptResponse & AccountIdPromptResponse & ClientIdPromptResponse & ClientSecretPromptResponse & ScopesPromptResponse;
|
|
20
|
-
|
|
21
|
-
* Displays notification to user that we are about to open the browser,
|
|
22
|
-
* then opens their browser to the personal-access-key shortlink
|
|
23
|
-
*/
|
|
24
|
-
export declare function personalAccessKeyPrompt({ env, account, }: {
|
|
20
|
+
export declare function legacyPersonalAccessKeyPrompt({ env, account, }: {
|
|
25
21
|
env: string;
|
|
26
22
|
account?: number;
|
|
27
23
|
}): Promise<PersonalAccessKeyPromptResponse>;
|
|
24
|
+
export declare function personalAccessKeyPrompt(): Promise<string>;
|
|
28
25
|
export declare const OAUTH_FLOW: (PromptConfig<AccountNamePromptResponse> | PromptConfig<AccountIdPromptResponse> | PromptConfig<ClientIdPromptResponse> | PromptConfig<ClientSecretPromptResponse> | PromptConfig<ScopesPromptResponse>)[];
|
|
29
26
|
export {};
|
|
@@ -6,13 +6,11 @@ import { uiLogger } from '../ui/logger.js';
|
|
|
6
6
|
import { promptUser } from './promptUtils.js';
|
|
7
7
|
import { getCliAccountNamePromptConfig, } from './accountNamePrompt.js';
|
|
8
8
|
import { uiInfoSection } from '../ui/index.js';
|
|
9
|
-
import { EXIT_CODES } from '../enums/exitCodes.js';
|
|
10
9
|
import { lib } from '../../lang/en.js';
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
export async function personalAccessKeyPrompt({ env, account, }) {
|
|
10
|
+
import { PromptExitError } from '../errors/PromptExitError.js';
|
|
11
|
+
import { EXIT_CODES } from '../enums/exitCodes.js';
|
|
12
|
+
// Full PAK flow: browser-open menu + paste. Used by commands that haven't adopted websocket PAK delivery.
|
|
13
|
+
export async function legacyPersonalAccessKeyPrompt({ env, account, }) {
|
|
16
14
|
const websiteOrigin = getHubSpotWebsiteOrigin(env);
|
|
17
15
|
let url = `${websiteOrigin}/l/personal-access-key`;
|
|
18
16
|
if (process.env.BROWSER !== 'none') {
|
|
@@ -27,7 +25,7 @@ export async function personalAccessKeyPrompt({ env, account, }) {
|
|
|
27
25
|
]);
|
|
28
26
|
if (!choice) {
|
|
29
27
|
deleteConfigFileIfEmpty();
|
|
30
|
-
|
|
28
|
+
throw new PromptExitError(lib.prompts.personalAccessKeyPrompt.errors.authCancelled, EXIT_CODES.SUCCESS);
|
|
31
29
|
}
|
|
32
30
|
if (choice ===
|
|
33
31
|
lib.prompts.personalAccessKeyPrompt.personalAccessKeyPromptChoices
|
|
@@ -42,6 +40,11 @@ export async function personalAccessKeyPrompt({ env, account, }) {
|
|
|
42
40
|
env,
|
|
43
41
|
};
|
|
44
42
|
}
|
|
43
|
+
// Paste-only: shows the masked input directly. Used by hs account auth after the browser is already open via websocket.
|
|
44
|
+
export async function personalAccessKeyPrompt() {
|
|
45
|
+
const { personalAccessKey } = await promptUser(PERSONAL_ACCESS_KEY);
|
|
46
|
+
return personalAccessKey;
|
|
47
|
+
}
|
|
45
48
|
const ACCOUNT_ID = {
|
|
46
49
|
name: 'accountId',
|
|
47
50
|
message: lib.prompts.personalAccessKeyPrompt.enterAccountId,
|
|
@@ -10,3 +10,4 @@ export declare function selectSandboxTargetAccountPrompt(accounts: HubSpotConfig
|
|
|
10
10
|
export declare function selectDeveloperTestTargetAccountPrompt(accounts: HubSpotConfigAccount[], defaultAccountConfig: HubSpotConfigAccount): Promise<ProjectDevTargetAccountPromptResponse>;
|
|
11
11
|
export declare function confirmDefaultAccountPrompt(accountName: string, accountType: string): Promise<boolean>;
|
|
12
12
|
export declare function confirmUseExistingDeveloperTestAccountPrompt(account: DeveloperTestAccount): Promise<boolean>;
|
|
13
|
+
export declare function confirmLinkExistingDeveloperTestAccountPrompt(accountName: string): Promise<boolean>;
|
|
@@ -6,6 +6,7 @@ import { lib } from '../../lang/en.js';
|
|
|
6
6
|
import { uiLogger } from '../ui/logger.js';
|
|
7
7
|
import { uiAccountDescription } from '../ui/index.js';
|
|
8
8
|
import { isSandbox } from '../accountTypes.js';
|
|
9
|
+
import { PromptExitError } from '../errors/PromptExitError.js';
|
|
9
10
|
import { EXIT_CODES } from '../enums/exitCodes.js';
|
|
10
11
|
function mapNestedAccount(accountConfig) {
|
|
11
12
|
const parentAccountId = accountConfig.parentAccountId ?? null;
|
|
@@ -23,20 +24,18 @@ function getNonConfigDeveloperTestAccountName(account) {
|
|
|
23
24
|
}
|
|
24
25
|
export async function selectSandboxTargetAccountPrompt(accounts, defaultAccountConfig) {
|
|
25
26
|
const defaultAccountId = defaultAccountConfig.accountId;
|
|
27
|
+
if (!defaultAccountId) {
|
|
28
|
+
uiLogger.error(lib.prompts.projectDevTargetAccountPrompt.noAccountId);
|
|
29
|
+
throw new PromptExitError(lib.prompts.projectDevTargetAccountPrompt.noAccountId, EXIT_CODES.ERROR);
|
|
30
|
+
}
|
|
26
31
|
let choices = [];
|
|
27
32
|
let sandboxUsage = {
|
|
28
33
|
STANDARD: { used: 0, available: 0, limit: 0 },
|
|
29
34
|
DEVELOPER: { used: 0, available: 0, limit: 0 },
|
|
30
35
|
};
|
|
31
36
|
try {
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
sandboxUsage = data.usage;
|
|
35
|
-
}
|
|
36
|
-
else {
|
|
37
|
-
uiLogger.error(lib.prompts.projectDevTargetAccountPrompt.noAccountId);
|
|
38
|
-
process.exit(EXIT_CODES.ERROR);
|
|
39
|
-
}
|
|
37
|
+
const { data } = await getSandboxUsageLimits(defaultAccountId);
|
|
38
|
+
sandboxUsage = data.usage;
|
|
40
39
|
}
|
|
41
40
|
catch (err) {
|
|
42
41
|
uiLogger.debug('Unable to fetch sandbox usage limits: ', err);
|
|
@@ -83,16 +82,14 @@ export async function selectSandboxTargetAccountPrompt(accounts, defaultAccountC
|
|
|
83
82
|
}
|
|
84
83
|
export async function selectDeveloperTestTargetAccountPrompt(accounts, defaultAccountConfig) {
|
|
85
84
|
const defaultAccountId = defaultAccountConfig.accountId;
|
|
85
|
+
if (!defaultAccountId) {
|
|
86
|
+
uiLogger.error(lib.prompts.projectDevTargetAccountPrompt.noAccountId);
|
|
87
|
+
throw new PromptExitError(lib.prompts.projectDevTargetAccountPrompt.noAccountId, EXIT_CODES.ERROR);
|
|
88
|
+
}
|
|
86
89
|
let devTestAccountsResponse;
|
|
87
90
|
try {
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
devTestAccountsResponse = data;
|
|
91
|
-
}
|
|
92
|
-
else {
|
|
93
|
-
uiLogger.error(lib.prompts.projectDevTargetAccountPrompt.noAccountId);
|
|
94
|
-
process.exit(EXIT_CODES.ERROR);
|
|
95
|
-
}
|
|
91
|
+
const { data } = await fetchDeveloperTestAccounts(defaultAccountId);
|
|
92
|
+
devTestAccountsResponse = data;
|
|
96
93
|
}
|
|
97
94
|
catch (err) {
|
|
98
95
|
uiLogger.debug('Unable to fetch developer test account usage limits: ', err);
|
|
@@ -167,3 +164,13 @@ export async function confirmUseExistingDeveloperTestAccountPrompt(account) {
|
|
|
167
164
|
]);
|
|
168
165
|
return confirmUseExistingDeveloperTestAccount;
|
|
169
166
|
}
|
|
167
|
+
export async function confirmLinkExistingDeveloperTestAccountPrompt(accountName) {
|
|
168
|
+
const { confirmLinkExistingDeveloperTestAccount } = await promptUser([
|
|
169
|
+
{
|
|
170
|
+
name: 'confirmLinkExistingDeveloperTestAccount',
|
|
171
|
+
type: 'confirm',
|
|
172
|
+
message: lib.prompts.projectDevTargetAccountPrompt.confirmLinkExistingDeveloperTestAccount(accountName),
|
|
173
|
+
},
|
|
174
|
+
]);
|
|
175
|
+
return confirmLinkExistingDeveloperTestAccount;
|
|
176
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import path from 'path';
|
|
2
|
+
import { getAllHsProfiles } from '@hubspot/project-parsing-lib/profiles';
|
|
3
|
+
import { listPrompt } from './promptUtils.js';
|
|
4
|
+
import { loadProfile } from '../projects/projectProfiles.js';
|
|
5
|
+
import { lib } from '../../lang/en.js';
|
|
6
|
+
function generateProfilePromptOption(projectDir, projectConfig, profileName) {
|
|
7
|
+
const choice = {
|
|
8
|
+
name: profileName,
|
|
9
|
+
value: profileName,
|
|
10
|
+
};
|
|
11
|
+
try {
|
|
12
|
+
const profile = loadProfile(projectConfig, projectDir, profileName);
|
|
13
|
+
choice.name = `${profileName} [${profile.accountId}]`;
|
|
14
|
+
}
|
|
15
|
+
catch (e) {
|
|
16
|
+
choice.name = `${profileName} [Invalid profile]`;
|
|
17
|
+
choice.disabled = true;
|
|
18
|
+
}
|
|
19
|
+
return choice;
|
|
20
|
+
}
|
|
21
|
+
export async function projectProfilePrompt(projectDir, projectConfig, profileName, exitIfMissing) {
|
|
22
|
+
if (profileName) {
|
|
23
|
+
return profileName;
|
|
24
|
+
}
|
|
25
|
+
const existingProfiles = await getAllHsProfiles(path.join(projectDir, projectConfig.srcDir));
|
|
26
|
+
if (existingProfiles.length !== 0) {
|
|
27
|
+
if (existingProfiles.length === 1) {
|
|
28
|
+
return existingProfiles[0];
|
|
29
|
+
}
|
|
30
|
+
// In automated workflows exit instead of prompting
|
|
31
|
+
if (exitIfMissing) {
|
|
32
|
+
throw new Error(lib.prompts.projectProfilePrompt.exitMessage);
|
|
33
|
+
}
|
|
34
|
+
const listOptions = existingProfiles.map(p => generateProfilePromptOption(projectDir, projectConfig, p));
|
|
35
|
+
const hasAnyValidProfiles = listOptions.some(option => typeof option === 'object' && 'name' in option && !option.disabled);
|
|
36
|
+
// Exit early if the user has no valid profiles for us to show in the prompt
|
|
37
|
+
if (!hasAnyValidProfiles) {
|
|
38
|
+
throw new Error(lib.prompts.projectProfilePrompt.noValidProfilesMessage);
|
|
39
|
+
}
|
|
40
|
+
const profileNameFromPrompt = await listPrompt(lib.prompts.projectProfilePrompt.message, {
|
|
41
|
+
choices: listOptions,
|
|
42
|
+
});
|
|
43
|
+
return profileNameFromPrompt;
|
|
44
|
+
}
|
|
45
|
+
return null;
|
|
46
|
+
}
|