@hubspot/cli 7.4.8 → 7.4.9-beta.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 (206) hide show
  1. package/commands/account/auth.d.ts +3 -7
  2. package/commands/account/auth.js +19 -9
  3. package/commands/account/clean.d.ts +3 -7
  4. package/commands/account/clean.js +16 -9
  5. package/commands/account/createOverride.d.ts +3 -7
  6. package/commands/account/createOverride.js +23 -6
  7. package/commands/account/info.d.ts +3 -7
  8. package/commands/account/info.js +13 -5
  9. package/commands/account/list.d.ts +3 -7
  10. package/commands/account/list.js +15 -8
  11. package/commands/account/remove.d.ts +3 -7
  12. package/commands/account/remove.js +21 -9
  13. package/commands/account/removeOverride.d.ts +3 -7
  14. package/commands/account/removeOverride.js +23 -6
  15. package/commands/account/rename.d.ts +3 -7
  16. package/commands/account/rename.js +16 -9
  17. package/commands/account/use.d.ts +5 -9
  18. package/commands/account/use.js +14 -6
  19. package/commands/account.d.ts +3 -4
  20. package/commands/account.js +35 -58
  21. package/commands/cms/convertFields.d.ts +7 -1
  22. package/commands/cms/convertFields.js +57 -41
  23. package/commands/cms/getReactModule.d.ts +7 -1
  24. package/commands/cms/getReactModule.js +52 -34
  25. package/commands/cms/lighthouseScore.d.ts +8 -1
  26. package/commands/cms/lighthouseScore.js +129 -100
  27. package/commands/cms.d.ts +3 -1
  28. package/commands/cms.js +24 -15
  29. package/commands/completion.d.ts +3 -1
  30. package/commands/completion.js +25 -12
  31. package/commands/config/migrate.d.ts +1 -1
  32. package/commands/config/migrate.js +16 -12
  33. package/commands/create/api-sample.d.ts +3 -1
  34. package/commands/create/api-sample.js +34 -38
  35. package/commands/create/app.d.ts +3 -1
  36. package/commands/create/app.js +9 -7
  37. package/commands/create/function.d.ts +3 -1
  38. package/commands/create/function.js +11 -10
  39. package/commands/create/index.d.ts +5 -1
  40. package/commands/create/index.js +23 -11
  41. package/commands/create/module.d.ts +3 -1
  42. package/commands/create/module.js +14 -13
  43. package/commands/create/react-app.d.ts +3 -1
  44. package/commands/create/react-app.js +10 -7
  45. package/commands/create/template.d.ts +3 -1
  46. package/commands/create/template.js +14 -14
  47. package/commands/create/vue-app.d.ts +3 -1
  48. package/commands/create/vue-app.js +10 -7
  49. package/commands/create/webpack-serverless.d.ts +3 -1
  50. package/commands/create/webpack-serverless.js +10 -7
  51. package/commands/create/website-theme.d.ts +3 -1
  52. package/commands/create/website-theme.js +10 -9
  53. package/commands/create.d.ts +4 -24
  54. package/commands/create.js +63 -74
  55. package/commands/customObject/create.d.ts +4 -9
  56. package/commands/customObject/create.js +17 -10
  57. package/commands/customObject/schema/create.d.ts +4 -9
  58. package/commands/customObject/schema/create.js +18 -11
  59. package/commands/customObject/schema/delete.d.ts +4 -9
  60. package/commands/customObject/schema/delete.js +17 -10
  61. package/commands/customObject/schema/fetch-all.d.ts +4 -9
  62. package/commands/customObject/schema/fetch-all.js +17 -10
  63. package/commands/customObject/schema/fetch.d.ts +4 -9
  64. package/commands/customObject/schema/fetch.js +17 -10
  65. package/commands/customObject/schema/list.d.ts +4 -8
  66. package/commands/customObject/schema/list.js +17 -10
  67. package/commands/customObject/schema/update.d.ts +4 -9
  68. package/commands/customObject/schema/update.js +18 -11
  69. package/commands/customObject/schema.d.ts +3 -5
  70. package/commands/customObject/schema.js +27 -54
  71. package/commands/customObject.d.ts +3 -4
  72. package/commands/customObject.js +20 -45
  73. package/commands/feedback.d.ts +4 -1
  74. package/commands/feedback.js +40 -47
  75. package/commands/fetch.d.ts +12 -1
  76. package/commands/fetch.js +49 -33
  77. package/commands/filemanager/fetch.d.ts +4 -9
  78. package/commands/filemanager/fetch.js +18 -11
  79. package/commands/filemanager/upload.d.ts +4 -9
  80. package/commands/filemanager/upload.js +17 -11
  81. package/commands/filemanager.d.ts +3 -4
  82. package/commands/filemanager.js +20 -41
  83. package/commands/function/deploy.d.ts +6 -1
  84. package/commands/function/deploy.js +70 -50
  85. package/commands/function/list.d.ts +6 -1
  86. package/commands/function/list.js +44 -32
  87. package/commands/function/server.d.ts +10 -1
  88. package/commands/function/server.js +49 -38
  89. package/commands/function.d.ts +5 -1
  90. package/commands/function.js +24 -10
  91. package/commands/hubdb/clear.d.ts +4 -9
  92. package/commands/hubdb/clear.js +17 -10
  93. package/commands/hubdb/create.d.ts +4 -9
  94. package/commands/hubdb/create.js +17 -10
  95. package/commands/hubdb/delete.d.ts +4 -9
  96. package/commands/hubdb/delete.js +17 -10
  97. package/commands/hubdb/fetch.d.ts +4 -9
  98. package/commands/hubdb/fetch.js +17 -10
  99. package/commands/hubdb.d.ts +3 -2
  100. package/commands/hubdb.js +23 -45
  101. package/commands/lint.d.ts +6 -4
  102. package/commands/lint.js +44 -43
  103. package/commands/logs.d.ts +10 -1
  104. package/commands/logs.js +53 -44
  105. package/commands/module/marketplace-validate.d.ts +6 -1
  106. package/commands/module/marketplace-validate.js +39 -27
  107. package/commands/module.d.ts +3 -1
  108. package/commands/module.js +22 -10
  109. package/commands/project/cloneApp.d.ts +1 -1
  110. package/commands/project/create.js +3 -3
  111. package/commands/project/deploy.d.ts +1 -0
  112. package/commands/project/deploy.js +40 -12
  113. package/commands/project/dev/index.d.ts +1 -4
  114. package/commands/project/dev/index.js +44 -15
  115. package/commands/project/dev/unifiedFlow.d.ts +2 -1
  116. package/commands/project/dev/unifiedFlow.js +52 -20
  117. package/commands/project/migrate.d.ts +1 -0
  118. package/commands/project/profile/add.d.ts +7 -0
  119. package/commands/project/profile/add.js +190 -0
  120. package/commands/project/profile/remove.d.ts +6 -0
  121. package/commands/project/profile/remove.js +119 -0
  122. package/commands/project/profile.d.ts +3 -0
  123. package/commands/project/profile.js +25 -0
  124. package/commands/project/upload.d.ts +1 -0
  125. package/commands/project/upload.js +38 -8
  126. package/commands/project.js +2 -0
  127. package/commands/sandbox/create.d.ts +4 -9
  128. package/commands/sandbox/create.js +18 -11
  129. package/commands/sandbox/delete.d.ts +4 -9
  130. package/commands/sandbox/delete.js +18 -11
  131. package/commands/sandbox.d.ts +3 -4
  132. package/commands/sandbox.js +20 -43
  133. package/commands/secret/addSecret.d.ts +4 -9
  134. package/commands/secret/addSecret.js +17 -10
  135. package/commands/secret/deleteSecret.d.ts +4 -9
  136. package/commands/secret/deleteSecret.js +17 -10
  137. package/commands/secret/listSecret.d.ts +4 -9
  138. package/commands/secret/listSecret.js +17 -10
  139. package/commands/secret/updateSecret.d.ts +4 -9
  140. package/commands/secret/updateSecret.js +17 -10
  141. package/commands/secret.d.ts +3 -4
  142. package/commands/secret.js +25 -48
  143. package/commands/theme/generate-selectors.d.ts +3 -7
  144. package/commands/theme/generate-selectors.js +14 -6
  145. package/commands/theme/marketplace-validate.d.ts +4 -9
  146. package/commands/theme/marketplace-validate.js +17 -10
  147. package/commands/theme/preview.d.ts +4 -9
  148. package/commands/theme/preview.js +16 -9
  149. package/commands/theme.d.ts +3 -4
  150. package/commands/theme.js +23 -46
  151. package/commands/upload.d.ts +12 -1
  152. package/commands/upload.js +118 -97
  153. package/commands/watch.d.ts +14 -1
  154. package/commands/watch.js +76 -65
  155. package/lang/en.d.ts +654 -558
  156. package/lang/en.js +443 -353
  157. package/lang/en.lyaml +23 -13
  158. package/lib/app/migrate.d.ts +23 -0
  159. package/lib/app/migrate.js +14 -3
  160. package/lib/app/migrate_legacy.js +5 -5
  161. package/lib/configMigrate.js +24 -10
  162. package/lib/constants.d.ts +6 -0
  163. package/lib/constants.js +7 -1
  164. package/lib/errorHandlers/suppressError.js +12 -19
  165. package/lib/filesystem.d.ts +1 -1
  166. package/lib/interpolation.d.ts +2 -3
  167. package/lib/lang.d.ts +2 -3
  168. package/lib/middleware/configMiddleware.js +8 -0
  169. package/lib/projectProfiles.d.ts +6 -0
  170. package/lib/projectProfiles.js +65 -0
  171. package/lib/projects/buildAndDeploy.js +17 -2
  172. package/lib/projects/localDev/AppDevModeInterface.d.ts +25 -0
  173. package/lib/projects/localDev/AppDevModeInterface.js +117 -0
  174. package/lib/projects/localDev/DevServerManagerV2.d.ts +11 -22
  175. package/lib/projects/localDev/DevServerManagerV2.js +19 -15
  176. package/lib/projects/localDev/LocalDevLogger.d.ts +30 -0
  177. package/lib/projects/localDev/LocalDevLogger.js +158 -0
  178. package/lib/projects/localDev/LocalDevManager.js +2 -3
  179. package/lib/projects/localDev/LocalDevProcess.d.ts +27 -0
  180. package/lib/projects/localDev/LocalDevProcess.js +171 -0
  181. package/lib/projects/localDev/LocalDevState.d.ts +37 -0
  182. package/lib/projects/localDev/LocalDevState.js +78 -0
  183. package/lib/projects/localDev/LocalDevWatcher.d.ts +10 -0
  184. package/lib/projects/localDev/LocalDevWatcher.js +56 -0
  185. package/lib/projects/localDev/LocalDevWebsocketServer.d.ts +17 -0
  186. package/lib/projects/localDev/LocalDevWebsocketServer.js +92 -0
  187. package/lib/projects/localDev/helpers.d.ts +1 -1
  188. package/lib/projects/localDev/helpers.js +2 -1
  189. package/lib/projects/upload.d.ts +2 -1
  190. package/lib/projects/upload.js +2 -2
  191. package/lib/prompts/createApiSamplePrompt.d.ts +2 -10
  192. package/lib/prompts/createTemplatePrompt.d.ts +22 -4
  193. package/lib/testUtils.d.ts +3 -3
  194. package/lib/testUtils.js +8 -9
  195. package/lib/upload.d.ts +1 -1
  196. package/lib/validation.js +4 -5
  197. package/lib/yargsUtils.d.ts +4 -0
  198. package/lib/yargsUtils.js +6 -0
  199. package/package.json +5 -3
  200. package/types/Cms.d.ts +30 -0
  201. package/types/Cms.js +2 -0
  202. package/types/LocalDev.d.ts +24 -0
  203. package/types/LocalDev.js +2 -0
  204. package/types/Yargs.d.ts +8 -1
  205. package/lib/projects/localDev/LocalDevManagerV2.d.ts +0 -64
  206. package/lib/projects/localDev/LocalDevManagerV2.js +0 -345
@@ -1,14 +1,26 @@
1
1
  "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
2
5
  Object.defineProperty(exports, "__esModule", { value: true });
3
- // @ts-nocheck
4
- const marketplaceValidate = require('./module/marketplace-validate');
5
- const { addConfigOptions, addAccountOptions, addGlobalOptions, } = require('../lib/commonOpts');
6
- exports.command = 'module';
7
- exports.describe = false;
8
- exports.builder = yargs => {
9
- addConfigOptions(yargs);
10
- addAccountOptions(yargs);
11
- addGlobalOptions(yargs);
12
- yargs.command(marketplaceValidate).demandCommand(1, '');
6
+ const marketplace_validate_1 = __importDefault(require("./module/marketplace-validate"));
7
+ const yargsUtils_1 = require("../lib/yargsUtils");
8
+ const command = 'module';
9
+ const describe = undefined;
10
+ function moduleBuilder(yargs) {
11
+ yargs.command(marketplace_validate_1.default).demandCommand(1, '');
13
12
  return yargs;
13
+ }
14
+ const builder = (0, yargsUtils_1.makeYargsBuilder)(moduleBuilder, command, describe, {
15
+ useGlobalOptions: true,
16
+ useConfigOptions: true,
17
+ useAccountOptions: true,
18
+ });
19
+ const moduleCommand = {
20
+ command,
21
+ describe,
22
+ builder,
23
+ handler: () => { },
14
24
  };
25
+ exports.default = moduleCommand;
26
+ module.exports = moduleCommand;
@@ -1,5 +1,5 @@
1
1
  import { AccountArgs, CommonArgs, ConfigArgs, EnvironmentArgs, YargsCommandModule } from '../../types/Yargs';
2
- export type CloneAppArgs = ConfigArgs & EnvironmentArgs & AccountArgs & CommonArgs & {
2
+ type CloneAppArgs = ConfigArgs & EnvironmentArgs & AccountArgs & CommonArgs & {
3
3
  dest: string;
4
4
  appId: number;
5
5
  };
@@ -34,17 +34,17 @@ async function handler(args) {
34
34
  }
35
35
  }
36
36
  catch (err) {
37
- logger_1.logger.error((0, lang_1.i18n)(`commands.project.subcommands.create.error.failedToFetchProjectList`));
37
+ logger_1.logger.error((0, lang_1.i18n)(`commands.project.subcommands.create.errors.failedToFetchProjectList`));
38
38
  process.exit(exitCodes_1.EXIT_CODES.ERROR);
39
39
  }
40
40
  }
41
41
  if (!templateSource || !templateSource.includes('/')) {
42
- logger_1.logger.error((0, lang_1.i18n)(`commands.project.subcommands.create.error.invalidTemplateSource`));
42
+ logger_1.logger.error((0, lang_1.i18n)(`commands.project.subcommands.create.errors.invalidTemplateSource`));
43
43
  process.exit(exitCodes_1.EXIT_CODES.ERROR);
44
44
  }
45
45
  const projectTemplates = await (0, create_1.getProjectTemplateListFromRepo)(templateSource, latestRepoReleaseTag || constants_1.DEFAULT_PROJECT_TEMPLATE_BRANCH);
46
46
  if (!projectTemplates.length) {
47
- logger_1.logger.error((0, lang_1.i18n)(`commands.project.subcommands.create.error.failedToFetchProjectList`));
47
+ logger_1.logger.error((0, lang_1.i18n)(`commands.project.subcommands.create.errors.failedToFetchProjectList`));
48
48
  process.exit(exitCodes_1.EXIT_CODES.ERROR);
49
49
  }
50
50
  const createProjectPromptResponse = await (0, createProjectPrompt_1.createProjectPrompt)(args, projectTemplates);
@@ -3,6 +3,7 @@ export type ProjectDeployArgs = CommonArgs & ConfigArgs & AccountArgs & Environm
3
3
  project?: string;
4
4
  build?: number;
5
5
  buildId?: number;
6
+ profile?: string;
6
7
  };
7
8
  declare const projectDeployCommand: YargsCommandModule<unknown, ProjectDeployArgs>;
8
9
  export default projectDeployCommand;
@@ -21,6 +21,7 @@ const ui_1 = require("../../lib/ui");
21
21
  const exitCodes_1 = require("../../lib/enums/exitCodes");
22
22
  const ui_2 = require("../../lib/ui");
23
23
  const yargsUtils_1 = require("../../lib/yargsUtils");
24
+ const projectProfiles_1 = require("../../lib/projectProfiles");
24
25
  const command = 'deploy';
25
26
  const describe = (0, ui_1.uiBetaTag)((0, lang_1.i18n)(`commands.project.subcommands.deploy.describe`), false);
26
27
  function validateBuildId(buildId, deployedBuildId, latestBuildId, projectName, accountId) {
@@ -40,29 +41,48 @@ function validateBuildId(buildId, deployedBuildId, latestBuildId, projectName, a
40
41
  return true;
41
42
  }
42
43
  async function handler(args) {
43
- const { derivedAccountId } = args;
44
+ const { derivedAccountId, project: projectOption, buildId: buildIdOption, } = args;
44
45
  const accountConfig = (0, config_1.getAccountConfig)(derivedAccountId);
45
- const { project: projectOption, buildId: buildIdOption } = args;
46
46
  const accountType = accountConfig && accountConfig.accountType;
47
- (0, usageTracking_1.trackCommandUsage)('project-deploy', accountType ? { type: accountType } : undefined, derivedAccountId);
48
- const { projectConfig } = await (0, config_2.getProjectConfig)();
47
+ let targetAccountId;
48
+ const { projectConfig, projectDir } = await (0, config_2.getProjectConfig)();
49
+ if ((0, buildAndDeploy_1.useV3Api)(projectConfig?.platformVersion)) {
50
+ if (args.profile) {
51
+ (0, projectProfiles_1.logProfileHeader)(args.profile);
52
+ const profile = (0, projectProfiles_1.loadProfile)(projectConfig, projectDir, args.profile);
53
+ if (!profile) {
54
+ (0, ui_1.uiLine)();
55
+ process.exit(exitCodes_1.EXIT_CODES.ERROR);
56
+ }
57
+ targetAccountId = profile.accountId;
58
+ (0, projectProfiles_1.logProfileFooter)(profile);
59
+ }
60
+ else {
61
+ // A profile must be specified if this project has profiles configured
62
+ await (0, projectProfiles_1.exitIfUsingProfiles)(projectConfig, projectDir);
63
+ }
64
+ }
65
+ if (!targetAccountId) {
66
+ targetAccountId = derivedAccountId;
67
+ }
68
+ (0, usageTracking_1.trackCommandUsage)('project-deploy', accountType ? { type: accountType } : undefined, targetAccountId);
49
69
  let projectName = projectOption;
50
70
  if (!projectOption && projectConfig) {
51
71
  projectName = projectConfig.name;
52
72
  }
53
- const namePromptResponse = await (0, projectNamePrompt_1.projectNamePrompt)(derivedAccountId, {
73
+ const namePromptResponse = await (0, projectNamePrompt_1.projectNamePrompt)(targetAccountId, {
54
74
  project: projectName,
55
75
  });
56
76
  projectName = namePromptResponse.projectName;
57
77
  let buildIdToDeploy = buildIdOption;
58
78
  try {
59
- const { data: { latestBuild, deployedBuildId }, } = await (0, projects_1.fetchProject)(derivedAccountId, projectName);
79
+ const { data: { latestBuild, deployedBuildId }, } = await (0, projects_1.fetchProject)(targetAccountId, projectName);
60
80
  if (!latestBuild || !latestBuild.buildId) {
61
81
  logger_1.logger.error((0, lang_1.i18n)(`commands.project.subcommands.deploy.errors.noBuilds`));
62
82
  return process.exit(exitCodes_1.EXIT_CODES.ERROR);
63
83
  }
64
84
  if (buildIdToDeploy) {
65
- const validationResult = validateBuildId(buildIdToDeploy, deployedBuildId, latestBuild.buildId, projectName, derivedAccountId);
85
+ const validationResult = validateBuildId(buildIdToDeploy, deployedBuildId, latestBuild.buildId, projectName, targetAccountId);
66
86
  if (validationResult !== true) {
67
87
  logger_1.logger.error(validationResult);
68
88
  return process.exit(exitCodes_1.EXIT_CODES.ERROR);
@@ -75,7 +95,7 @@ async function handler(args) {
75
95
  default: latestBuild.buildId === deployedBuildId
76
96
  ? undefined
77
97
  : latestBuild.buildId,
78
- validate: buildId => validateBuildId(buildId, deployedBuildId, latestBuild.buildId, projectName, derivedAccountId),
98
+ validate: buildId => validateBuildId(buildId, deployedBuildId, latestBuild.buildId, projectName, targetAccountId),
79
99
  });
80
100
  buildIdToDeploy = deployBuildIdPromptResponse.buildId;
81
101
  }
@@ -83,18 +103,18 @@ async function handler(args) {
83
103
  logger_1.logger.error((0, lang_1.i18n)(`commands.project.subcommands.deploy.errors.noBuildId`));
84
104
  return process.exit(exitCodes_1.EXIT_CODES.ERROR);
85
105
  }
86
- const { data: deployResp } = await (0, projects_1.deployProject)(derivedAccountId, projectName, buildIdToDeploy, (0, buildAndDeploy_1.useV3Api)(projectConfig?.platformVersion));
106
+ const { data: deployResp } = await (0, projects_1.deployProject)(targetAccountId, projectName, buildIdToDeploy, (0, buildAndDeploy_1.useV3Api)(projectConfig?.platformVersion));
87
107
  if (!deployResp) {
88
108
  logger_1.logger.error((0, lang_1.i18n)(`commands.project.subcommands.deploy.errors.deploy`));
89
109
  return process.exit(exitCodes_1.EXIT_CODES.ERROR);
90
110
  }
91
- await (0, buildAndDeploy_2.pollDeployStatus)(derivedAccountId, projectName, Number(deployResp.id), buildIdToDeploy);
111
+ await (0, buildAndDeploy_2.pollDeployStatus)(targetAccountId, projectName, Number(deployResp.id), buildIdToDeploy);
92
112
  }
93
113
  catch (e) {
94
114
  if ((0, index_1.isHubSpotHttpError)(e) && e.status === 404) {
95
115
  logger_1.logger.error((0, lang_1.i18n)(`commands.project.subcommands.deploy.errors.projectNotFound`, {
96
116
  projectName: chalk_1.default.bold(projectName),
97
- accountIdentifier: (0, ui_2.uiAccountDescription)(derivedAccountId),
117
+ accountIdentifier: (0, ui_2.uiAccountDescription)(targetAccountId),
98
118
  command: (0, ui_2.uiCommandReference)('hs project upload'),
99
119
  }));
100
120
  }
@@ -103,7 +123,7 @@ async function handler(args) {
103
123
  }
104
124
  else {
105
125
  (0, index_2.logError)(e, new index_2.ApiErrorContext({
106
- accountId: derivedAccountId,
126
+ accountId: targetAccountId,
107
127
  request: 'project deploy',
108
128
  }));
109
129
  }
@@ -121,7 +141,15 @@ function projectDeployBuilder(yargs) {
121
141
  describe: (0, lang_1.i18n)(`commands.project.subcommands.deploy.options.build.describe`),
122
142
  type: 'number',
123
143
  },
144
+ profile: {
145
+ alias: ['p'],
146
+ describe: (0, lang_1.i18n)(`commands.project.subcommands.deploy.options.profile.describe`),
147
+ type: 'string',
148
+ hidden: true,
149
+ },
124
150
  });
151
+ yargs.conflicts('profile', 'project');
152
+ yargs.conflicts('profile', 'account');
125
153
  yargs.example([
126
154
  [
127
155
  '$0 project deploy',
@@ -1,8 +1,5 @@
1
- import { ArgumentsCamelCase, Argv, CommandModule } from 'yargs';
1
+ import { Argv, CommandModule } from 'yargs';
2
2
  import { ProjectDevArgs } from '../../../types/Yargs';
3
- export declare const command = "dev";
4
- export declare const describe: string;
5
- export declare function handler(args: ArgumentsCamelCase<ProjectDevArgs>): Promise<void>;
6
3
  export declare const builder: (yargs: Argv) => Promise<Argv<ProjectDevArgs>>;
7
4
  declare const projectDevCommand: CommandModule<unknown, ProjectDevArgs>;
8
5
  export default projectDevCommand;
@@ -1,7 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.builder = exports.describe = exports.command = void 0;
4
- exports.handler = handler;
3
+ exports.builder = void 0;
5
4
  const usageTracking_1 = require("../../../lib/usageTracking");
6
5
  const lang_1 = require("../../../lib/lang");
7
6
  const logger_1 = require("@hubspot/local-dev-lib/logger");
@@ -13,52 +12,82 @@ const deprecatedFlow_1 = require("./deprecatedFlow");
13
12
  const unifiedFlow_1 = require("./unifiedFlow");
14
13
  const buildAndDeploy_1 = require("../../../lib/projects/buildAndDeploy");
15
14
  const yargsUtils_1 = require("../../../lib/yargsUtils");
16
- exports.command = 'dev';
17
- exports.describe = (0, ui_1.uiBetaTag)((0, lang_1.i18n)(`commands.project.subcommands.dev.describe`), false);
15
+ const projectProfiles_1 = require("../../../lib/projectProfiles");
16
+ const command = 'dev';
17
+ const describe = (0, ui_1.uiBetaTag)((0, lang_1.i18n)(`commands.project.subcommands.dev.describe`), false);
18
18
  async function handler(args) {
19
- const { derivedAccountId } = args;
20
- const accountConfig = (0, config_1.getAccountConfig)(derivedAccountId);
21
- (0, usageTracking_1.trackCommandUsage)('project-dev', {}, derivedAccountId);
19
+ const { derivedAccountId, providedAccountId } = args;
22
20
  const { projectConfig, projectDir } = await (0, config_2.getProjectConfig)();
23
- (0, ui_1.uiBetaTag)((0, lang_1.i18n)(`commands.project.subcommands.dev.logs.betaMessage`));
24
- logger_1.logger.log((0, ui_1.uiLink)((0, lang_1.i18n)(`commands.project.subcommands.dev.logs.learnMoreLocalDevServer`), 'https://developers.hubspot.com/docs/platform/project-cli-commands#start-a-local-development-server'));
25
- if (!projectConfig || !projectDir) {
21
+ (0, config_2.validateProjectConfig)(projectConfig, projectDir);
22
+ if (!projectDir) {
26
23
  logger_1.logger.error((0, lang_1.i18n)(`commands.project.subcommands.dev.errors.noProjectConfig`, {
27
24
  accountId: derivedAccountId,
28
25
  authCommand: (0, ui_1.uiCommandReference)('hs auth'),
29
26
  }));
30
27
  process.exit(exitCodes_1.EXIT_CODES.ERROR);
31
28
  }
29
+ let targetAccountId = providedAccountId;
30
+ let profile;
31
+ if (!targetAccountId && (0, buildAndDeploy_1.useV3Api)(projectConfig.platformVersion)) {
32
+ if (args.profile) {
33
+ (0, projectProfiles_1.logProfileHeader)(args.profile);
34
+ profile = (0, projectProfiles_1.loadProfile)(projectConfig, projectDir, args.profile);
35
+ if (!profile) {
36
+ (0, ui_1.uiLine)();
37
+ process.exit(exitCodes_1.EXIT_CODES.ERROR);
38
+ }
39
+ targetAccountId = profile.accountId;
40
+ (0, projectProfiles_1.logProfileFooter)(profile);
41
+ }
42
+ else {
43
+ // A profile must be specified if this project has profiles configured
44
+ await (0, projectProfiles_1.exitIfUsingProfiles)(projectConfig, projectDir);
45
+ }
46
+ }
47
+ if (!targetAccountId) {
48
+ // The user is not using profiles, so we can use the derived accountId
49
+ targetAccountId = derivedAccountId;
50
+ }
51
+ (0, usageTracking_1.trackCommandUsage)('project-dev', {}, targetAccountId);
52
+ const accountConfig = (0, config_1.getAccountConfig)(targetAccountId);
53
+ (0, ui_1.uiBetaTag)((0, lang_1.i18n)(`commands.project.subcommands.dev.logs.betaMessage`));
54
+ logger_1.logger.log((0, ui_1.uiLink)((0, lang_1.i18n)(`commands.project.subcommands.dev.logs.learnMoreLocalDevServer`), 'https://developers.hubspot.com/docs/platform/project-cli-commands#start-a-local-development-server'));
32
55
  if (!accountConfig) {
33
56
  logger_1.logger.error((0, lang_1.i18n)(`commands.project.subcommands.dev.errors.noAccount`));
34
57
  process.exit(exitCodes_1.EXIT_CODES.ERROR);
35
58
  }
36
- (0, config_2.validateProjectConfig)(projectConfig, projectDir);
37
59
  if ((0, buildAndDeploy_1.useV3Api)(projectConfig.platformVersion)) {
38
- await (0, unifiedFlow_1.unifiedProjectDevFlow)(args, accountConfig, projectConfig, projectDir);
60
+ await (0, unifiedFlow_1.unifiedProjectDevFlow)(args, accountConfig, projectConfig, projectDir, profile);
39
61
  }
40
62
  else {
41
63
  await (0, deprecatedFlow_1.deprecatedProjectDevFlow)(args, accountConfig, projectConfig, projectDir);
42
64
  }
43
65
  }
44
66
  function projectDevBuilder(yargs) {
67
+ yargs.option('profile', {
68
+ type: 'string',
69
+ alias: 'p',
70
+ description: (0, lang_1.i18n)(`commands.project.subcommands.dev.options.profile`),
71
+ hidden: true,
72
+ });
45
73
  yargs.example([
46
74
  [
47
75
  '$0 project dev',
48
76
  (0, lang_1.i18n)(`commands.project.subcommands.dev.examples.default`),
49
77
  ],
50
78
  ]);
79
+ yargs.conflicts('profile', 'account');
51
80
  return yargs;
52
81
  }
53
- exports.builder = (0, yargsUtils_1.makeYargsBuilder)(projectDevBuilder, exports.command, exports.describe, {
82
+ exports.builder = (0, yargsUtils_1.makeYargsBuilder)(projectDevBuilder, command, describe, {
54
83
  useGlobalOptions: true,
55
84
  useAccountOptions: true,
56
85
  useConfigOptions: true,
57
86
  useEnvironmentOptions: true,
58
87
  });
59
88
  const projectDevCommand = {
60
- command: exports.command,
61
- describe: exports.describe,
89
+ command,
90
+ describe,
62
91
  handler,
63
92
  builder: exports.builder,
64
93
  };
@@ -1,5 +1,6 @@
1
1
  import { ArgumentsCamelCase } from 'yargs';
2
+ import { HsProfileFile } from '@hubspot/project-parsing-lib/src/lib/types';
2
3
  import { CLIAccount } from '@hubspot/local-dev-lib/types/Accounts';
3
4
  import { ProjectDevArgs } from '../../../types/Yargs';
4
5
  import { ProjectConfig } from '../../../types/Projects';
5
- export declare function unifiedProjectDevFlow(args: ArgumentsCamelCase<ProjectDevArgs>, accountConfig: CLIAccount, projectConfig: ProjectConfig, projectDir: string): Promise<void>;
6
+ export declare function unifiedProjectDevFlow(args: ArgumentsCamelCase<ProjectDevArgs>, accountConfig: CLIAccount, projectConfig: ProjectConfig, projectDir: string, profileConfig?: HsProfileFile): Promise<void>;
@@ -7,6 +7,7 @@ exports.unifiedProjectDevFlow = unifiedProjectDevFlow;
7
7
  const path_1 = __importDefault(require("path"));
8
8
  const util_1 = __importDefault(require("util"));
9
9
  const logger_1 = require("@hubspot/local-dev-lib/logger");
10
+ const getAccountIdentifier_1 = require("@hubspot/local-dev-lib/config/getAccountIdentifier");
10
11
  const errors_1 = require("@hubspot/project-parsing-lib/src/lib/errors");
11
12
  const project_parsing_lib_1 = require("@hubspot/project-parsing-lib");
12
13
  const config_1 = require("@hubspot/local-dev-lib/config");
@@ -17,15 +18,19 @@ const ensureProjectExists_1 = require("../../../lib/projects/ensureProjectExists
17
18
  const helpers_1 = require("../../../lib/projects/localDev/helpers");
18
19
  const projectDevTargetAccountPrompt_1 = require("../../../lib/prompts/projectDevTargetAccountPrompt");
19
20
  const SpinniesManager_1 = __importDefault(require("../../../lib/ui/SpinniesManager"));
20
- const LocalDevManagerV2_1 = __importDefault(require("../../../lib/projects/localDev/LocalDevManagerV2"));
21
+ const LocalDevProcess_1 = __importDefault(require("../../../lib/projects/localDev/LocalDevProcess"));
22
+ const LocalDevWatcher_1 = __importDefault(require("../../../lib/projects/localDev/LocalDevWatcher"));
21
23
  const process_1 = require("../../../lib/process");
22
24
  const accountTypes_1 = require("../../../lib/accountTypes");
23
25
  const ui_1 = require("../../../lib/ui");
24
26
  const lang_1 = require("../../../lib/lang");
25
- async function unifiedProjectDevFlow(args, accountConfig, projectConfig, projectDir) {
26
- logger_1.logger.log('Unified Apps Local Dev');
27
- const targetProjectAccountId = args.derivedAccountId;
27
+ // import LocalDevWebsocketServer from '../../../lib/projects/localDev/LocalDevWebsocketServer';
28
+ async function unifiedProjectDevFlow(args, accountConfig, projectConfig, projectDir, profileConfig) {
29
+ const targetProjectAccountId = (0, getAccountIdentifier_1.getAccountIdentifier)(accountConfig);
28
30
  const env = (0, environment_1.getValidEnv)((0, config_1.getEnv)(targetProjectAccountId));
31
+ if (!targetProjectAccountId) {
32
+ process.exit(exitCodes_1.EXIT_CODES.ERROR);
33
+ }
29
34
  let projectNodes;
30
35
  // Get IR
31
36
  try {
@@ -33,7 +38,7 @@ async function unifiedProjectDevFlow(args, accountConfig, projectConfig, project
33
38
  projectSourceDir: path_1.default.join(projectDir, projectConfig.srcDir),
34
39
  platformVersion: projectConfig.platformVersion,
35
40
  accountId: targetProjectAccountId,
36
- });
41
+ }, { profile: args.profile });
37
42
  projectNodes = intermediateRepresentation.intermediateNodesIndexedByUid;
38
43
  logger_1.logger.debug(util_1.default.inspect(projectNodes, false, null, true));
39
44
  }
@@ -59,23 +64,29 @@ async function unifiedProjectDevFlow(args, accountConfig, projectConfig, project
59
64
  // TODO Ideally this should require the user to target a Combined account
60
65
  // For now, check if the account is either developer or standard
61
66
  const derivedAccountIsRecommendedType = (0, accountTypes_1.isAppDeveloperAccount)(accountConfig) || (0, accountTypes_1.isStandardAccount)(accountConfig);
62
- if (!derivedAccountIsRecommendedType) {
67
+ if (!derivedAccountIsRecommendedType && !profileConfig) {
63
68
  logger_1.logger.error((0, lang_1.i18n)(`commands.project.subcommands.dev.errors.invalidUnifiedAppsAccount`), {
64
69
  authCommand: (0, ui_1.uiCommandReference)('hs auth'),
65
70
  });
66
71
  process.exit(exitCodes_1.EXIT_CODES.SUCCESS);
67
72
  }
68
73
  let targetTestingAccountId = null;
69
- const devAccountPromptResponse = await (0, projectDevTargetAccountPrompt_1.selectDeveloperTestTargetAccountPrompt)(accounts, accountConfig);
70
- targetTestingAccountId = devAccountPromptResponse.targetAccountId;
71
- if (!!devAccountPromptResponse.notInConfigAccount) {
72
- // When the developer test account isn't configured in the CLI config yet
73
- // Walk the user through adding the account's PAK to the config
74
- await (0, helpers_1.useExistingDevTestAccount)(env, devAccountPromptResponse.notInConfigAccount);
74
+ if (profileConfig) {
75
+ // Bypass the prompt for the testing account if the user has a profile configured
76
+ targetTestingAccountId = profileConfig.accountId;
75
77
  }
76
- else if (devAccountPromptResponse.createNestedAccount) {
77
- // Create a new developer test account and automatically add it to the CLI config
78
- targetTestingAccountId = await (0, helpers_1.createDeveloperTestAccountForLocalDev)(targetProjectAccountId, accountConfig, env);
78
+ else {
79
+ const devAccountPromptResponse = await (0, projectDevTargetAccountPrompt_1.selectDeveloperTestTargetAccountPrompt)(accounts, accountConfig);
80
+ targetTestingAccountId = devAccountPromptResponse.targetAccountId;
81
+ if (!!devAccountPromptResponse.notInConfigAccount) {
82
+ // When the developer test account isn't configured in the CLI config yet
83
+ // Walk the user through adding the account's PAK to the config
84
+ await (0, helpers_1.useExistingDevTestAccount)(env, devAccountPromptResponse.notInConfigAccount);
85
+ }
86
+ else if (devAccountPromptResponse.createNestedAccount) {
87
+ // Create a new developer test account and automatically add it to the CLI config
88
+ targetTestingAccountId = await (0, helpers_1.createDeveloperTestAccountForLocalDev)(targetProjectAccountId, accountConfig, env);
89
+ }
79
90
  }
80
91
  // Check if project exists in HubSpot
81
92
  const { projectExists, project: uploadedProject } = await (0, ensureProjectExists_1.ensureProjectExists)(targetProjectAccountId, projectConfig.name, {
@@ -92,10 +103,11 @@ async function unifiedProjectDevFlow(args, accountConfig, projectConfig, project
92
103
  }
93
104
  else {
94
105
  project = await (0, helpers_1.createNewProjectForLocalDev)(projectConfig, targetProjectAccountId, false, false);
95
- deployedBuild = await (0, helpers_1.createInitialBuildForNewProject)(projectConfig, projectDir, targetProjectAccountId, true);
106
+ deployedBuild = await (0, helpers_1.createInitialBuildForNewProject)(projectConfig, projectDir, targetProjectAccountId, true, args.profile);
96
107
  }
97
- const LocalDev = new LocalDevManagerV2_1.default({
98
- projectNodes,
108
+ // End setup, start local dev process
109
+ const localDevProcess = new LocalDevProcess_1.default({
110
+ initialProjectNodes: projectNodes,
99
111
  debug: args.debug,
100
112
  deployedBuild,
101
113
  isGithubLinked,
@@ -106,6 +118,26 @@ async function unifiedProjectDevFlow(args, accountConfig, projectConfig, project
106
118
  projectId: project.id,
107
119
  env,
108
120
  });
109
- await LocalDev.start();
110
- (0, process_1.handleExit)(({ isSIGHUP }) => LocalDev.stop(!isSIGHUP));
121
+ await localDevProcess.start();
122
+ const watcher = new LocalDevWatcher_1.default(localDevProcess);
123
+ watcher.start();
124
+ // const websocketServer = new LocalDevWebsocketServer(
125
+ // localDevProcess,
126
+ // args.debug
127
+ // );
128
+ // await websocketServer.start();
129
+ (0, process_1.handleKeypress)(async (key) => {
130
+ if ((key.ctrl && key.name === 'c') || key.name === 'q') {
131
+ await Promise.all([
132
+ localDevProcess.stop(),
133
+ watcher.stop(),
134
+ // websocketServer.shutdown(),
135
+ ]);
136
+ }
137
+ });
138
+ (0, process_1.handleExit)(({ isSIGHUP }) => {
139
+ localDevProcess.stop(!isSIGHUP);
140
+ watcher.stop();
141
+ // websocketServer.shutdown();
142
+ });
111
143
  }
@@ -1,6 +1,7 @@
1
1
  import { AccountArgs, CommonArgs, ConfigArgs, EnvironmentArgs, YargsCommandModule } from '../../types/Yargs';
2
2
  export type ProjectMigrateArgs = CommonArgs & AccountArgs & EnvironmentArgs & ConfigArgs & {
3
3
  platformVersion: string;
4
+ unstable: boolean;
4
5
  };
5
6
  declare const migrateCommand: YargsCommandModule<unknown, ProjectMigrateArgs>;
6
7
  export default migrateCommand;
@@ -0,0 +1,7 @@
1
+ import { YargsCommandModule, CommonArgs } from '../../../types/Yargs';
2
+ type ProjectProfileAddArgs = CommonArgs & {
3
+ name?: string;
4
+ targetAccount?: number;
5
+ };
6
+ declare const projectProfileAddCommand: YargsCommandModule<unknown, ProjectProfileAddArgs>;
7
+ export default projectProfileAddCommand;
@@ -0,0 +1,190 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const path_1 = __importDefault(require("path"));
7
+ const fs_1 = __importDefault(require("fs"));
8
+ const config_1 = require("@hubspot/local-dev-lib/config");
9
+ const getAccountIdentifier_1 = require("@hubspot/local-dev-lib/config/getAccountIdentifier");
10
+ const project_parsing_lib_1 = require("@hubspot/project-parsing-lib");
11
+ const usageTracking_1 = require("../../../lib/usageTracking");
12
+ const config_2 = require("../../../lib/projects/config");
13
+ const ui_1 = require("../../../lib/ui");
14
+ const logger_1 = require("../../../lib/ui/logger");
15
+ const exitCodes_1 = require("../../../lib/enums/exitCodes");
16
+ const yargsUtils_1 = require("../../../lib/yargsUtils");
17
+ const en_1 = require("../../../lang/en");
18
+ const promptUtils_1 = require("../../../lib/prompts/promptUtils");
19
+ const validation_1 = require("../../../lib/validation");
20
+ const command = 'add [name]';
21
+ const describe = (0, ui_1.uiBetaTag)(en_1.commands.project.profile.add.describe, false);
22
+ const verboseDescribe = (0, ui_1.uiBetaTag)(en_1.commands.project.profile.add.verboseDescribe, false);
23
+ async function selectProfileToCopyVariablesFrom(projectSourceDir) {
24
+ const existingProfiles = await (0, project_parsing_lib_1.getAllHsProfiles)(projectSourceDir);
25
+ let profileToCopyVariablesFrom;
26
+ if (existingProfiles.length == 1) {
27
+ logger_1.uiLogger.log('');
28
+ logger_1.uiLogger.log(en_1.commands.project.profile.add.logs.copyExistingProfile((0, project_parsing_lib_1.getHsProfileFilename)(existingProfiles[0])));
29
+ const shouldCopyVariables = await (0, promptUtils_1.confirmPrompt)('Copy profile variables?', {
30
+ defaultAnswer: true,
31
+ });
32
+ if (shouldCopyVariables) {
33
+ profileToCopyVariablesFrom = existingProfiles[0];
34
+ }
35
+ }
36
+ else if (existingProfiles.length > 1) {
37
+ logger_1.uiLogger.log('');
38
+ logger_1.uiLogger.log(en_1.commands.project.profile.add.logs.copyExistingProfiles);
39
+ const emptyChoice = {
40
+ name: en_1.commands.project.profile.add.prompts.copyExistingProfilePromptEmpty,
41
+ value: undefined,
42
+ };
43
+ const promptResponse = await (0, promptUtils_1.listPrompt)(en_1.commands.project.profile.add.prompts.copyExistingProfilePrompt, {
44
+ choices: [
45
+ ...existingProfiles.map(profile => ({
46
+ name: (0, project_parsing_lib_1.getHsProfileFilename)(profile),
47
+ value: profile,
48
+ })),
49
+ emptyChoice,
50
+ ],
51
+ });
52
+ if (promptResponse) {
53
+ profileToCopyVariablesFrom = promptResponse;
54
+ }
55
+ }
56
+ return profileToCopyVariablesFrom;
57
+ }
58
+ async function handler(args) {
59
+ const { derivedAccountId } = args;
60
+ (0, usageTracking_1.trackCommandUsage)('project-profile-add', undefined, derivedAccountId);
61
+ const { projectConfig, projectDir } = await (0, config_2.getProjectConfig)();
62
+ if (!projectConfig || !projectDir) {
63
+ logger_1.uiLogger.error(en_1.commands.project.profile.add.errors.noProjectConfig);
64
+ process.exit(exitCodes_1.EXIT_CODES.ERROR);
65
+ }
66
+ const projectSourceDir = path_1.default.join(projectDir, projectConfig.srcDir);
67
+ let profileName = args.name;
68
+ let targetAccount = args.targetAccount;
69
+ function checkIfProfileExists(profileName) {
70
+ return (0, validation_1.fileExists)(path_1.default.join(projectSourceDir, (0, project_parsing_lib_1.getHsProfileFilename)(profileName)));
71
+ }
72
+ function isValidProfileName(profileName) {
73
+ const trimmedProfileName = profileName.trim();
74
+ if (trimmedProfileName === '') {
75
+ return en_1.commands.project.profile.add.prompts.emptyName;
76
+ }
77
+ if (!/^[a-zA-Z0-9]+$/.test(trimmedProfileName)) {
78
+ return en_1.commands.project.profile.add.prompts.invalidProfileName;
79
+ }
80
+ if (checkIfProfileExists(trimmedProfileName)) {
81
+ return en_1.commands.project.profile.add.errors.profileExists(trimmedProfileName);
82
+ }
83
+ return true;
84
+ }
85
+ if (profileName) {
86
+ if (checkIfProfileExists(profileName)) {
87
+ logger_1.uiLogger.error(en_1.commands.project.profile.add.errors.profileExists((0, project_parsing_lib_1.getHsProfileFilename)(profileName)));
88
+ logger_1.uiLogger.log('');
89
+ profileName = undefined;
90
+ }
91
+ else {
92
+ const validationResult = isValidProfileName(profileName);
93
+ if (validationResult !== true) {
94
+ logger_1.uiLogger.error(validationResult);
95
+ logger_1.uiLogger.log('');
96
+ profileName = undefined;
97
+ }
98
+ }
99
+ }
100
+ if (!profileName) {
101
+ const promptResponse = await (0, promptUtils_1.promptUser)({
102
+ type: 'input',
103
+ name: 'name',
104
+ message: en_1.commands.project.profile.add.prompts.namePrompt,
105
+ validate: isValidProfileName,
106
+ });
107
+ profileName = promptResponse.name;
108
+ }
109
+ if (targetAccount) {
110
+ const accountId = (0, config_1.getAccountId)(targetAccount);
111
+ if (accountId) {
112
+ targetAccount = accountId;
113
+ }
114
+ else {
115
+ logger_1.uiLogger.error(en_1.commands.project.profile.add.errors.invalidTargetAccount);
116
+ logger_1.uiLogger.log('');
117
+ targetAccount = undefined;
118
+ }
119
+ }
120
+ if (!targetAccount) {
121
+ const configuredAccounts = (0, config_1.getConfigAccounts)();
122
+ if (!configuredAccounts || !configuredAccounts.length) {
123
+ logger_1.uiLogger.error(en_1.commands.project.profile.add.errors.noAccountsConfigured);
124
+ process.exit(exitCodes_1.EXIT_CODES.ERROR);
125
+ }
126
+ const promptResponse = await (0, promptUtils_1.listPrompt)(en_1.commands.project.profile.add.prompts.targetAccountPrompt, {
127
+ choices: configuredAccounts.map(account => {
128
+ const accountId = (0, getAccountIdentifier_1.getAccountIdentifier)(account);
129
+ return {
130
+ name: (0, ui_1.uiAccountDescription)(accountId),
131
+ value: accountId,
132
+ };
133
+ }),
134
+ });
135
+ if (promptResponse) {
136
+ targetAccount = promptResponse;
137
+ }
138
+ }
139
+ const profileFileContent = {
140
+ accountId: Number(targetAccount),
141
+ variables: {},
142
+ };
143
+ const profileToCopyVariablesFrom = await selectProfileToCopyVariablesFrom(projectSourceDir);
144
+ if (profileToCopyVariablesFrom) {
145
+ try {
146
+ const profileToCopyFileContent = (0, project_parsing_lib_1.loadHsProfileFile)(projectSourceDir, profileToCopyVariablesFrom);
147
+ if (profileToCopyFileContent?.variables) {
148
+ profileFileContent.variables = profileToCopyFileContent.variables;
149
+ }
150
+ }
151
+ catch (err) {
152
+ logger_1.uiLogger.error(en_1.commands.project.profile.add.errors.failedToLoadProfile(profileToCopyVariablesFrom));
153
+ }
154
+ }
155
+ const profileFilename = (0, project_parsing_lib_1.getHsProfileFilename)(profileName);
156
+ try {
157
+ fs_1.default.writeFileSync(path_1.default.join(projectSourceDir, profileFilename), JSON.stringify(profileFileContent, null, 2), 'utf8');
158
+ }
159
+ catch (err) {
160
+ logger_1.uiLogger.error(en_1.commands.project.profile.add.errors.failedToCreateProfile);
161
+ process.exit(exitCodes_1.EXIT_CODES.ERROR);
162
+ }
163
+ logger_1.uiLogger.log('');
164
+ logger_1.uiLogger.log(en_1.commands.project.profile.add.logs.profileAdded(profileFilename));
165
+ process.exit(exitCodes_1.EXIT_CODES.SUCCESS);
166
+ }
167
+ function projectProfileAddBuilder(yargs) {
168
+ yargs.positional('name', {
169
+ describe: en_1.commands.project.profile.add.positionals.name,
170
+ type: 'string',
171
+ });
172
+ yargs.option('target-account', {
173
+ describe: en_1.commands.project.profile.add.options.targetAccount,
174
+ type: 'number',
175
+ });
176
+ yargs.example([
177
+ ['$0 project profile add qa', en_1.commands.project.profile.add.example],
178
+ ]);
179
+ return yargs;
180
+ }
181
+ const builder = (0, yargsUtils_1.makeYargsBuilder)(projectProfileAddBuilder, command, verboseDescribe, {
182
+ useGlobalOptions: true,
183
+ });
184
+ const projectProfileAddCommand = {
185
+ command,
186
+ describe,
187
+ handler,
188
+ builder,
189
+ };
190
+ exports.default = projectProfileAddCommand;