@pnp/cli-microsoft365 8.0.0-beta.5dade25 → 8.0.0-beta.630e741

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 (31) hide show
  1. package/allCommands.json +1 -1
  2. package/allCommandsFull.json +1 -1
  3. package/dist/Auth.js +1 -9
  4. package/dist/chili/chili.js +0 -23
  5. package/dist/cli/cli.js +1 -63
  6. package/dist/m365/commands/setup.js +0 -4
  7. package/dist/m365/external/commands/connection/connection-doctor.js +10 -24
  8. package/dist/m365/flow/commands/flow-list.js +21 -23
  9. package/dist/m365/spfx/commands/project/base-project-command.js +36 -126
  10. package/dist/m365/spo/commands/cdn/cdn-get.js +12 -15
  11. package/dist/m365/spo/commands/cdn/cdn-set.js +6 -4
  12. package/dist/m365/spo/commands/contenttype/contenttype-field-list.js +124 -0
  13. package/dist/m365/spo/commands/field/field-list.js +1 -1
  14. package/dist/m365/spo/commands/group/group-member-add.js +103 -99
  15. package/dist/m365/spo/commands/page/page-clientsidewebpart-add.js +2 -3
  16. package/dist/m365/spo/commands/page/page-text-add.js +2 -3
  17. package/dist/m365/spo/commands/spo-search.js +3 -4
  18. package/dist/m365/spo/commands.js +1 -0
  19. package/dist/m365/teams/commands/meeting/meeting-attendancereport-get.js +119 -0
  20. package/dist/m365/teams/commands.js +1 -0
  21. package/dist/utils/formatting.js +14 -1
  22. package/dist/utils/validation.js +19 -0
  23. package/docs/docs/cmd/external/connection/connection-doctor.mdx +9 -9
  24. package/docs/docs/cmd/flow/flow-list.mdx +114 -56
  25. package/docs/docs/cmd/spo/cdn/cdn-set.mdx +3 -3
  26. package/docs/docs/cmd/spo/contenttype/contenttype-field-list.mdx +172 -0
  27. package/docs/docs/cmd/spo/field/field-list.mdx +3 -3
  28. package/docs/docs/cmd/spo/group/group-member-add.mdx +34 -27
  29. package/docs/docs/cmd/teams/meeting/meeting-attendancereport-get.mdx +138 -0
  30. package/npm-shrinkwrap.json +0 -195
  31. package/package.json +2 -2
package/dist/Auth.js CHANGED
@@ -354,15 +354,7 @@ export class Auth {
354
354
  await logger.logToStderr(response);
355
355
  await logger.logToStderr('');
356
356
  }
357
- cli.spinner.text = response.message;
358
- cli.spinner.spinner = {
359
- frames: ['🌶️ ']
360
- };
361
- // don't show spinner if running tests
362
- /* c8 ignore next 3 */
363
- if (!cli.spinner.isSpinning && typeof global.it === 'undefined') {
364
- cli.spinner.start();
365
- }
357
+ await logger.logToStderr(`🌶️ ${response.message}`);
366
358
  if (cli.getSettingWithDefaultValue(settingsNames.autoOpenLinksInBrowser, false)) {
367
359
  await browserUtil.open(response.verificationUri);
368
360
  }
@@ -1,22 +1,17 @@
1
1
  import fs from 'fs';
2
- import ora from 'ora';
3
2
  import path from 'path';
4
3
  import url from 'url';
5
- import { cli } from '../cli/cli.js';
6
4
  import request from '../request.js';
7
- import { settingsNames } from '../settingsNames.js';
8
5
  import { md } from '../utils/md.js';
9
6
  import { prompt } from '../utils/prompt.js';
10
7
  const __dirname = url.fileURLToPath(new URL('.', import.meta.url));
11
8
  const mendableBaseUrl = 'https://api.mendable.ai/v1';
12
9
  const mendableApiKey = 'd3313d54-6f8e-40e0-90d3-4095019d4be7';
13
- const spinner = ora({ discardStdin: false });
14
10
  let showHelp = false;
15
11
  let debug = false;
16
12
  let conversationId = 0;
17
13
  let initialPrompt = '';
18
14
  let history = [];
19
- const showSpinner = cli.getSettingWithDefaultValue(settingsNames.showSpinner, true) && typeof global.it === 'undefined';
20
15
  request.logger = {
21
16
  /* c8 ignore next 3 */
22
17
  log: async (msg) => console.log(msg),
@@ -74,20 +69,11 @@ async function promptForPrompt() {
74
69
  }
75
70
  async function runConversationTurn(conversationId, question) {
76
71
  console.log('');
77
- /* c8 ignore next 4 */
78
- if (showSpinner) {
79
- spinner.text = 'Searching documentation...';
80
- spinner.start();
81
- }
82
72
  const response = await runMendableChat(conversationId, question);
83
73
  history.push({
84
74
  prompt: question,
85
75
  response: response.answer.text
86
76
  });
87
- /* c8 ignore next 3 */
88
- if (showSpinner) {
89
- spinner.stop();
90
- }
91
77
  console.log(md.md2plain(response.answer.text, ''));
92
78
  console.log('');
93
79
  console.log('Source:');
@@ -141,16 +127,7 @@ async function endConversation(conversationId) {
141
127
  conversation_id: conversationId
142
128
  }
143
129
  };
144
- /* c8 ignore next 4 */
145
- if (showSpinner) {
146
- spinner.text = 'Ending conversation...';
147
- spinner.start();
148
- }
149
130
  await request.post(requestOptions);
150
- /* c8 ignore next 3 */
151
- if (showSpinner) {
152
- spinner.stop();
153
- }
154
131
  }
155
132
  async function runMendableChat(conversationId, question) {
156
133
  const requestOptions = {
package/dist/cli/cli.js CHANGED
@@ -2,7 +2,6 @@ import Configstore from 'configstore';
2
2
  import fs from 'fs';
3
3
  import minimist from 'minimist';
4
4
  import { createRequire } from 'module';
5
- import ora from 'ora';
6
5
  import os from 'os';
7
6
  import path from 'path';
8
7
  import { fileURLToPath, pathToFileURL } from 'url';
@@ -21,9 +20,6 @@ import { browserUtil } from '../utils/browserUtil.js';
21
20
  const require = createRequire(import.meta.url);
22
21
  const __dirname = fileURLToPath(new URL('.', import.meta.url));
23
22
  let _config;
24
- // we assign it through exported function to support mocking
25
- // eslint-disable-next-line prefer-const
26
- let spinner = ora();
27
23
  const commands = [];
28
24
  /**
29
25
  * Command to execute
@@ -190,12 +186,6 @@ async function executeCommand(command, args) {
190
186
  // the command to execute
191
187
  const parentCommandName = cli.currentCommandName;
192
188
  cli.currentCommandName = command.getCommandName(cli.currentCommandName);
193
- const showSpinner = cli.getSettingWithDefaultValue(settingsNames.showSpinner, true) && args.options.output !== 'none';
194
- // don't show spinner if running tests
195
- /* c8 ignore next 3 */
196
- if (showSpinner && typeof global.it === 'undefined') {
197
- cli.spinner.start();
198
- }
199
189
  const startCommand = process.hrtime.bigint();
200
190
  try {
201
191
  await command.action(logger, args);
@@ -207,10 +197,6 @@ async function executeCommand(command, args) {
207
197
  finally {
208
198
  // restore the original command name
209
199
  cli.currentCommandName = parentCommandName;
210
- /* c8 ignore next 3 */
211
- if (cli.spinner.isSpinning) {
212
- cli.spinner.stop();
213
- }
214
200
  const endCommand = process.hrtime.bigint();
215
201
  timings.command.push(Number(endCommand - startCommand));
216
202
  }
@@ -758,29 +744,14 @@ async function closeWithError(error, args, showHelpIfEnabled = false) {
758
744
  /* c8 ignore next */
759
745
  }
760
746
  function log(message, ...optionalParams) {
761
- const spinnerSpinning = cli.spinner.isSpinning;
762
- /* c8 ignore next 3 */
763
- if (spinnerSpinning) {
764
- cli.spinner.stop();
765
- }
766
747
  if (message) {
767
748
  console.log(message, ...optionalParams);
768
749
  }
769
750
  else {
770
751
  console.log();
771
752
  }
772
- // Restart the spinner if it was running before the log
773
- /* c8 ignore next 3 */
774
- if (spinnerSpinning) {
775
- cli.spinner.start();
776
- }
777
753
  }
778
754
  async function error(message, ...optionalParams) {
779
- const spinnerSpinning = cli.spinner.isSpinning;
780
- /* c8 ignore next 3 */
781
- if (spinnerSpinning) {
782
- cli.spinner.stop();
783
- }
784
755
  const errorOutput = cli.getSettingWithDefaultValue(settingsNames.errorOutput, 'stderr');
785
756
  if (errorOutput === 'stdout') {
786
757
  console.log(message, ...optionalParams);
@@ -788,40 +759,15 @@ async function error(message, ...optionalParams) {
788
759
  else {
789
760
  console.error(message, ...optionalParams);
790
761
  }
791
- // Restart the spinner if it was running before the log
792
- /* c8 ignore next 3 */
793
- if (spinnerSpinning) {
794
- cli.spinner.start();
795
- }
796
762
  }
797
763
  async function promptForSelection(config) {
798
- const spinnerSpinning = cli.spinner.isSpinning;
799
- /* c8 ignore next 3 */
800
- if (spinnerSpinning) {
801
- cli.spinner.stop();
802
- }
803
764
  const answer = await prompt.forSelection(config);
804
765
  await cli.error('');
805
- // Restart the spinner if it was running before the prompt
806
- /* c8 ignore next 3 */
807
- if (spinnerSpinning) {
808
- cli.spinner.start();
809
- }
810
766
  return answer;
811
767
  }
812
768
  async function promptForConfirmation(config) {
813
- const spinnerSpinning = cli.spinner.isSpinning;
814
- /* c8 ignore next 3 */
815
- if (spinnerSpinning) {
816
- cli.spinner.stop();
817
- }
818
769
  const answer = await prompt.forConfirmation(config);
819
770
  await cli.error('');
820
- // Restart the spinner if it was running before the prompt
821
- /* c8 ignore next 3 */
822
- if (spinnerSpinning) {
823
- cli.spinner.start();
824
- }
825
771
  return answer;
826
772
  }
827
773
  async function handleMultipleResultsFound(message, values) {
@@ -885,14 +831,6 @@ export const cli = {
885
831
  printAvailableCommands,
886
832
  promptForConfirmation,
887
833
  promptForSelection,
888
- shouldTrimOutput,
889
- spinner
890
- };
891
- const spinnerOptions = {
892
- text: 'Running command...',
893
- /* c8 ignore next 1 */
894
- stream: cli.getSettingWithDefaultValue('errorOutput', 'stderr') === 'stderr' ? process.stderr : process.stdout,
895
- discardStdin: false
834
+ shouldTrimOutput
896
835
  };
897
- cli.spinner = ora(spinnerOptions);
898
836
  //# sourceMappingURL=cli.js.map
@@ -42,8 +42,6 @@ class SetupCommand extends AnonymousCommand {
42
42
  await this.configureSettings(settings, true, logger);
43
43
  return;
44
44
  }
45
- // stop the spinner. Fixes #5598
46
- cli.spinner.stop();
47
45
  await logger.logToStderr(`Welcome to the CLI for Microsoft 365 setup!`);
48
46
  await logger.logToStderr(`This command will guide you through the process of configuring the CLI for your needs.`);
49
47
  await logger.logToStderr(`Please, answer the following questions and we'll define a set of settings to best match how you intend to use the CLI.`);
@@ -85,8 +83,6 @@ class SetupCommand extends AnonymousCommand {
85
83
  await logger.logToStderr('');
86
84
  await logger.logToStderr('Configuring settings...');
87
85
  await logger.logToStderr('');
88
- // start the spinner. Fixes #5598
89
- cli.spinner.start();
90
86
  await this.configureSettings(settings, false, logger);
91
87
  if (!this.verbose) {
92
88
  await logger.logToStderr('');
@@ -5,11 +5,10 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
5
5
  };
6
6
  var _ExternalConnectionDoctorCommand_instances, _a, _ExternalConnectionDoctorCommand_initOptions, _ExternalConnectionDoctorCommand_initValidators;
7
7
  import os from 'os';
8
- import { cli } from '../../../../cli/cli.js';
9
8
  import request from '../../../../request.js';
10
- import { settingsNames } from '../../../../settingsNames.js';
11
9
  import GraphCommand from '../../../base/GraphCommand.js';
12
10
  import commands from '../../commands.js';
11
+ import { CheckStatus, formatting } from '../../../../utils/formatting.js';
13
12
  class ExternalConnectionDoctorCommand extends GraphCommand {
14
13
  get name() {
15
14
  return commands.CONNECTION_DOCTOR;
@@ -28,9 +27,7 @@ class ExternalConnectionDoctorCommand extends GraphCommand {
28
27
  const ux = args.options.ux ?? 'all';
29
28
  const output = args.options.output;
30
29
  this.checksStatus = [];
31
- const showSpinner = cli.getSettingWithDefaultValue(settingsNames.showSpinner, true) &&
32
- output === 'text' &&
33
- typeof global.it === 'undefined';
30
+ const show = output === 'text';
34
31
  let checks = [
35
32
  {
36
33
  id: 'loadExternalConnection',
@@ -114,17 +111,10 @@ class ExternalConnectionDoctorCommand extends GraphCommand {
114
111
  if (this.debug) {
115
112
  await logger.logToStderr(`Running check ${check.id}...`);
116
113
  }
117
- // don't show spinner if running tests
118
- /* c8 ignore next 3 */
119
- if (showSpinner) {
120
- cli.spinner.start(check.text);
121
- }
122
114
  // only automated checks have functions
123
115
  if (!check.fn) {
124
- // don't show spinner if running tests
125
- /* c8 ignore next 3 */
126
- if (showSpinner) {
127
- cli.spinner.info(`${check.text} (manual)`);
116
+ if (show) {
117
+ await logger.log(formatting.getStatus(CheckStatus.Information, `${check.text} (manual)`));
128
118
  }
129
119
  this.checksStatus.push({
130
120
  ...check,
@@ -135,23 +125,19 @@ class ExternalConnectionDoctorCommand extends GraphCommand {
135
125
  const result = await check.fn.bind(this)(check.id, args);
136
126
  this.checksStatus.push({ ...check, ...result });
137
127
  if (result.status === 'passed') {
138
- // don't show spinner if running tests
139
- /* c8 ignore next 3 */
140
- if (showSpinner) {
141
- cli.spinner.succeed();
128
+ if (show) {
129
+ await logger.log(formatting.getStatus(CheckStatus.Success, check.text));
142
130
  }
143
131
  continue;
144
132
  }
145
133
  if (result.status === 'failed') {
146
- // don't show spinner if running tests
147
- /* c8 ignore next 9 */
148
- if (showSpinner) {
134
+ if (show) {
149
135
  const message = `${check.text}: ${result.errorMessage}`;
150
136
  if (check.type === 'required') {
151
- cli.spinner.fail(message);
137
+ await logger.log(formatting.getStatus(CheckStatus.Failure, message));
152
138
  }
153
139
  else {
154
- cli.spinner.warn(message);
140
+ await logger.log(formatting.getStatus(CheckStatus.Warning, check.text));
155
141
  }
156
142
  }
157
143
  if (result.shouldStop) {
@@ -159,7 +145,7 @@ class ExternalConnectionDoctorCommand extends GraphCommand {
159
145
  }
160
146
  }
161
147
  }
162
- if (output === 'text' || output === 'none') {
148
+ if (show || output === 'none') {
163
149
  return;
164
150
  }
165
151
  this.checksStatus.forEach(s => {
@@ -3,7 +3,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
3
3
  if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
4
4
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
5
5
  };
6
- var _FlowListCommand_instances, _FlowListCommand_initTelemetry, _FlowListCommand_initOptions, _FlowListCommand_initValidators;
6
+ var _FlowListCommand_instances, _FlowListCommand_initTelemetry, _FlowListCommand_initOptions, _FlowListCommand_initValidators, _FlowListCommand_initTypes;
7
7
  import { formatting } from '../../../utils/formatting.js';
8
8
  import { odata } from '../../../utils/odata.js';
9
9
  import PowerAutomateCommand from '../../base/PowerAutomateCommand.js';
@@ -13,7 +13,7 @@ class FlowListCommand extends PowerAutomateCommand {
13
13
  return commands.LIST;
14
14
  }
15
15
  get description() {
16
- return 'Lists Microsoft Flows in the given environment';
16
+ return 'Lists Power Automate flows in the given environment';
17
17
  }
18
18
  defaultProperties() {
19
19
  return ['name', 'displayName'];
@@ -25,8 +25,12 @@ class FlowListCommand extends PowerAutomateCommand {
25
25
  __classPrivateFieldGet(this, _FlowListCommand_instances, "m", _FlowListCommand_initTelemetry).call(this);
26
26
  __classPrivateFieldGet(this, _FlowListCommand_instances, "m", _FlowListCommand_initOptions).call(this);
27
27
  __classPrivateFieldGet(this, _FlowListCommand_instances, "m", _FlowListCommand_initValidators).call(this);
28
+ __classPrivateFieldGet(this, _FlowListCommand_instances, "m", _FlowListCommand_initTypes).call(this);
28
29
  }
29
30
  async commandAction(logger, args) {
31
+ if (this.verbose) {
32
+ await logger.logToStderr(`Getting Power Automate flows${args.options.asAdmin && ' as admin'} in environment '${args.options.environmentName}'...`);
33
+ }
30
34
  try {
31
35
  const { environmentName, asAdmin, sharingStatus, includeSolutions } = args.options;
32
36
  let items = [];
@@ -50,34 +54,25 @@ class FlowListCommand extends PowerAutomateCommand {
50
54
  }
51
55
  // Remove duplicates
52
56
  items = items.filter((flow, index, self) => index === self.findIndex(f => f.id === flow.id));
53
- if (items.length > 0) {
54
- items.forEach(i => {
55
- i.displayName = i.properties.displayName;
57
+ if (args.options.output && args.options.output !== 'json') {
58
+ items.forEach(flow => {
59
+ flow.displayName = flow.properties.displayName;
56
60
  });
57
- await logger.log(items);
58
- }
59
- else {
60
- if (this.verbose) {
61
- await logger.logToStderr('No Flows found');
62
- }
63
61
  }
62
+ await logger.log(items);
64
63
  }
65
64
  catch (err) {
66
65
  this.handleRejectedODataJsonPromise(err);
67
66
  }
68
67
  }
69
68
  getApiUrl(environmentName, asAdmin, includeSolutionFlows, filter) {
70
- let url = `${this.resource}/providers/Microsoft.ProcessSimple${asAdmin ? '/scopes/admin' : ''}/environments/${formatting.encodeQueryParameter(environmentName)}/flows?api-version=2016-11-01`;
71
- if (filter === 'personal') {
72
- url += `&$filter=search('personal')`;
73
- }
74
- else if (filter === 'team') {
75
- url += `&$filter=search('team')`;
76
- }
77
- if (includeSolutionFlows) {
78
- url += '&include=includeSolutionCloudFlows';
79
- }
80
- return url;
69
+ const baseEndpoint = `${this.resource}/providers/Microsoft.ProcessSimple`;
70
+ const environmentSegment = `/environments/${formatting.encodeQueryParameter(environmentName)}`;
71
+ const adminSegment = `/scopes/admin${environmentSegment}/v2`;
72
+ const flowsEndpoint = '/flows?api-version=2016-11-01';
73
+ const filterQuery = filter === 'personal' || filter === 'team' ? `&$filter=search('${filter}')` : '';
74
+ const includeQuery = includeSolutionFlows ? '&include=includeSolutionCloudFlows' : '';
75
+ return `${baseEndpoint}${asAdmin ? adminSegment : environmentSegment}${flowsEndpoint}${filterQuery}${includeQuery}`;
81
76
  }
82
77
  }
83
78
  _FlowListCommand_instances = new WeakSet(), _FlowListCommand_initTelemetry = function _FlowListCommand_initTelemetry() {
@@ -105,10 +100,13 @@ _FlowListCommand_instances = new WeakSet(), _FlowListCommand_initTelemetry = fun
105
100
  return `The options asAdmin and sharingStatus cannot be specified together.`;
106
101
  }
107
102
  if (args.options.sharingStatus && !this.allowedSharingStatuses.some(status => status === args.options.sharingStatus)) {
108
- return `${args.options.sharingStatus} is not a valid sharing status. Allowed values are: ${this.allowedSharingStatuses.join(',')}`;
103
+ return `${args.options.sharingStatus} is not a valid sharing status. Allowed values are: ${this.allowedSharingStatuses.join(', ')}`;
109
104
  }
110
105
  return true;
111
106
  });
107
+ }, _FlowListCommand_initTypes = function _FlowListCommand_initTypes() {
108
+ this.types.string.push('environmentName', 'sharingStatus');
109
+ this.types.boolean.push('includeSolutions', 'asAdmin');
112
110
  };
113
111
  export default new FlowListCommand();
114
112
  //# sourceMappingURL=flow-list.js.map
@@ -4,6 +4,7 @@ import { formatting } from '../../../../utils/formatting.js';
4
4
  import { fsUtil } from '../../../../utils/fsUtil.js';
5
5
  import AnonymousCommand from "../../../base/AnonymousCommand.js";
6
6
  import { ScssFile, TsFile } from "./project-model/index.js";
7
+ import { CommandError } from '../../../../Command.js';
7
8
  export class BaseProjectCommand extends AnonymousCommand {
8
9
  constructor() {
9
10
  super(...arguments);
@@ -31,105 +32,17 @@ export class BaseProjectCommand extends AnonymousCommand {
31
32
  }
32
33
  catch { }
33
34
  }
34
- const configJsonPath = path.join(projectRootPath, 'config/config.json');
35
- if (fs.existsSync(configJsonPath)) {
36
- try {
37
- const source = formatting.removeSingleLineComments(fs.readFileSync(configJsonPath, 'utf-8'));
38
- project.configJson = JSON.parse(source);
39
- project.configJson.source = source;
40
- }
41
- catch { }
42
- }
43
- const copyAssetsJsonPath = path.join(projectRootPath, 'config/copy-assets.json');
44
- if (fs.existsSync(copyAssetsJsonPath)) {
45
- try {
46
- const source = formatting.removeSingleLineComments(fs.readFileSync(copyAssetsJsonPath, 'utf-8'));
47
- project.copyAssetsJson = JSON.parse(source);
48
- project.copyAssetsJson.source = source;
49
- }
50
- catch { }
51
- }
52
- const deployAzureStorageJsonPath = path.join(projectRootPath, 'config/deploy-azure-storage.json');
53
- if (fs.existsSync(deployAzureStorageJsonPath)) {
54
- try {
55
- const source = formatting.removeSingleLineComments(fs.readFileSync(deployAzureStorageJsonPath, 'utf-8'));
56
- project.deployAzureStorageJson = JSON.parse(source);
57
- project.deployAzureStorageJson.source = source;
58
- }
59
- catch { }
60
- }
61
- const packageJsonPath = path.join(projectRootPath, 'package.json');
62
- if (fs.existsSync(packageJsonPath)) {
63
- try {
64
- const source = formatting.removeSingleLineComments(fs.readFileSync(packageJsonPath, 'utf-8'));
65
- project.packageJson = JSON.parse(source);
66
- project.packageJson.source = source;
67
- }
68
- catch { }
69
- }
70
- const packageSolutionJsonPath = path.join(projectRootPath, 'config/package-solution.json');
71
- if (fs.existsSync(packageSolutionJsonPath)) {
72
- try {
73
- const source = formatting.removeSingleLineComments(fs.readFileSync(packageSolutionJsonPath, 'utf-8'));
74
- project.packageSolutionJson = JSON.parse(source);
75
- project.packageSolutionJson.source = source;
76
- }
77
- catch { }
78
- }
79
- const serveJsonPath = path.join(projectRootPath, 'config/serve.json');
80
- if (fs.existsSync(serveJsonPath)) {
81
- try {
82
- const source = formatting.removeSingleLineComments(fs.readFileSync(serveJsonPath, 'utf-8'));
83
- project.serveJson = JSON.parse(source);
84
- project.serveJson.source = source;
85
- }
86
- catch { }
87
- }
88
- const tsConfigJsonPath = path.join(projectRootPath, 'tsconfig.json');
89
- if (fs.existsSync(tsConfigJsonPath)) {
90
- try {
91
- const source = formatting.removeSingleLineComments(fs.readFileSync(tsConfigJsonPath, 'utf-8'));
92
- project.tsConfigJson = JSON.parse(source);
93
- project.tsConfigJson.source = source;
94
- }
95
- catch { }
96
- }
97
- const tsLintJsonPath = path.join(projectRootPath, 'config/tslint.json');
98
- if (fs.existsSync(tsLintJsonPath)) {
99
- try {
100
- const source = formatting.removeSingleLineComments(fs.readFileSync(tsLintJsonPath, 'utf-8'));
101
- project.tsLintJson = JSON.parse(source);
102
- project.tsLintJson.source = source;
103
- }
104
- catch { }
105
- }
106
- const tsLintJsonRootPath = path.join(projectRootPath, 'tslint.json');
107
- if (fs.existsSync(tsLintJsonRootPath)) {
108
- try {
109
- const source = formatting.removeSingleLineComments(fs.readFileSync(tsLintJsonRootPath, 'utf-8'));
110
- project.tsLintJsonRoot = JSON.parse(source);
111
- project.tsLintJsonRoot.source = source;
112
- }
113
- catch { }
114
- }
115
- const writeManifestJsonPath = path.join(projectRootPath, 'config/write-manifests.json');
116
- if (fs.existsSync(writeManifestJsonPath)) {
117
- try {
118
- const source = formatting.removeSingleLineComments(fs.readFileSync(writeManifestJsonPath, 'utf-8'));
119
- project.writeManifestsJson = JSON.parse(source);
120
- project.writeManifestsJson.source = source;
121
- }
122
- catch { }
123
- }
124
- const yoRcJsonPath = path.join(projectRootPath, '.yo-rc.json');
125
- if (fs.existsSync(yoRcJsonPath)) {
126
- try {
127
- const source = formatting.removeSingleLineComments(fs.readFileSync(yoRcJsonPath, 'utf-8'));
128
- project.yoRcJson = JSON.parse(source);
129
- project.yoRcJson.source = source;
130
- }
131
- catch { }
132
- }
35
+ this.readAndParseJsonFile(path.join(projectRootPath, 'config', 'config.json'), project, 'configJson');
36
+ this.readAndParseJsonFile(path.join(projectRootPath, 'config', 'copy-assets.json'), project, 'copyAssetsJson');
37
+ this.readAndParseJsonFile(path.join(projectRootPath, 'config', 'deploy-azure-storage.json'), project, 'deployAzureStorageJson');
38
+ this.readAndParseJsonFile(path.join(projectRootPath, 'package.json'), project, 'packageJson');
39
+ this.readAndParseJsonFile(path.join(projectRootPath, 'config', 'package-solution.json'), project, 'packageSolutionJson');
40
+ this.readAndParseJsonFile(path.join(projectRootPath, 'config', 'serve.json'), project, 'serveJson');
41
+ this.readAndParseJsonFile(path.join(projectRootPath, 'tsconfig.json'), project, 'tsConfigJson');
42
+ this.readAndParseJsonFile(path.join(projectRootPath, 'config', 'tslint.json'), project, 'tsLintJson');
43
+ this.readAndParseJsonFile(path.join(projectRootPath, 'tslint.json'), project, 'tsLintJsonRoot');
44
+ this.readAndParseJsonFile(path.join(projectRootPath, 'config', 'write-manifests.json'), project, 'writeManifestsJson');
45
+ this.readAndParseJsonFile(path.join(projectRootPath, '.yo-rc.json'), project, 'yoRcJson');
133
46
  const gulpfileJsPath = path.join(projectRootPath, 'gulpfile.js');
134
47
  if (fs.existsSync(gulpfileJsPath)) {
135
48
  project.gulpfileJs = {
@@ -141,33 +54,9 @@ export class BaseProjectCommand extends AnonymousCommand {
141
54
  project.esLintRcJs = new TsFile(esLintRcJsPath);
142
55
  }
143
56
  project.vsCode = {};
144
- const vsCodeSettingsPath = path.join(projectRootPath, '.vscode', 'settings.json');
145
- if (fs.existsSync(vsCodeSettingsPath)) {
146
- try {
147
- const source = formatting.removeSingleLineComments(fs.readFileSync(vsCodeSettingsPath, 'utf-8'));
148
- project.vsCode.settingsJson = JSON.parse(source);
149
- project.vsCode.settingsJson.source = source;
150
- }
151
- catch { }
152
- }
153
- const vsCodeExtensionsPath = path.join(projectRootPath, '.vscode', 'extensions.json');
154
- if (fs.existsSync(vsCodeExtensionsPath)) {
155
- try {
156
- const source = formatting.removeSingleLineComments(fs.readFileSync(vsCodeExtensionsPath, 'utf-8'));
157
- project.vsCode.extensionsJson = JSON.parse(source);
158
- project.vsCode.extensionsJson.source = source;
159
- }
160
- catch { }
161
- }
162
- const vsCodeLaunchPath = path.join(projectRootPath, '.vscode', 'launch.json');
163
- if (fs.existsSync(vsCodeLaunchPath)) {
164
- try {
165
- const source = formatting.removeSingleLineComments(fs.readFileSync(vsCodeLaunchPath, 'utf-8'));
166
- project.vsCode.launchJson = JSON.parse(source);
167
- project.vsCode.launchJson.source = source;
168
- }
169
- catch { }
170
- }
57
+ this.readAndParseJsonFile(path.join(projectRootPath, '.vscode', 'settings.json'), project, 'vsCode.settingsJson');
58
+ this.readAndParseJsonFile(path.join(projectRootPath, '.vscode', 'extensions.json'), project, 'vsCode.extensionsJson');
59
+ this.readAndParseJsonFile(path.join(projectRootPath, '.vscode', 'launch.json'), project, 'vsCode.launchJson');
171
60
  const srcFiles = fsUtil.readdirR(path.join(projectRootPath, 'src'));
172
61
  const manifestFiles = srcFiles.filter(f => f.endsWith('.manifest.json'));
173
62
  const manifests = manifestFiles.map((f) => {
@@ -233,5 +122,26 @@ export class BaseProjectCommand extends AnonymousCommand {
233
122
  catch { }
234
123
  return undefined;
235
124
  }
125
+ readAndParseJsonFile(filePath, project, keyPath) {
126
+ if (fs.existsSync(filePath)) {
127
+ try {
128
+ const source = formatting.removeSingleLineComments(fs.readFileSync(filePath, 'utf-8'));
129
+ const keys = keyPath.split('.');
130
+ let current = project;
131
+ for (let i = 0; i < keys.length - 1; i++) {
132
+ current = current[keys[i]];
133
+ }
134
+ const finalKey = keys[keys.length - 1];
135
+ current[finalKey] = JSON.parse(source);
136
+ if (typeof current[finalKey] === 'object' && current[finalKey] !== null) {
137
+ current[finalKey].source = source;
138
+ }
139
+ }
140
+ catch (error) {
141
+ throw new CommandError(`The file ${filePath} is not a valid JSON file or is not utf-8 encoded. Error: ${error}`);
142
+ }
143
+ }
144
+ return project;
145
+ }
236
146
  }
237
147
  //# sourceMappingURL=base-project-command.js.map
@@ -3,7 +3,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
3
3
  if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
4
4
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
5
5
  };
6
- var _SpoCdnGetCommand_instances, _SpoCdnGetCommand_initTelemetry, _SpoCdnGetCommand_initOptions, _SpoCdnGetCommand_initValidators;
6
+ var _SpoCdnGetCommand_instances, _SpoCdnGetCommand_initTelemetry, _SpoCdnGetCommand_initOptions, _SpoCdnGetCommand_initValidators, _SpoCdnGetCommand_initTypes;
7
7
  import config from '../../../../config.js';
8
8
  import request from '../../../../request.js';
9
9
  import { spo } from '../../../../utils/spo.js';
@@ -19,9 +19,11 @@ class SpoCdnGetCommand extends SpoCommand {
19
19
  constructor() {
20
20
  super();
21
21
  _SpoCdnGetCommand_instances.add(this);
22
+ this.validTypes = ['Public', 'Private'];
22
23
  __classPrivateFieldGet(this, _SpoCdnGetCommand_instances, "m", _SpoCdnGetCommand_initTelemetry).call(this);
23
24
  __classPrivateFieldGet(this, _SpoCdnGetCommand_instances, "m", _SpoCdnGetCommand_initOptions).call(this);
24
25
  __classPrivateFieldGet(this, _SpoCdnGetCommand_instances, "m", _SpoCdnGetCommand_initValidators).call(this);
26
+ __classPrivateFieldGet(this, _SpoCdnGetCommand_instances, "m", _SpoCdnGetCommand_initTypes).call(this);
25
27
  }
26
28
  async commandAction(logger, args) {
27
29
  const cdnTypeString = args.options.type || 'Public';
@@ -48,15 +50,11 @@ class SpoCdnGetCommand extends SpoCommand {
48
50
  if (response.ErrorInfo) {
49
51
  throw response.ErrorInfo.ErrorMessage;
50
52
  }
51
- else {
52
- const result = json[json.length - 1];
53
- if (this.verbose) {
54
- await logger.logToStderr(`${(cdnType === 0 ? 'Public' : 'Private')} CDN at ${spoAdminUrl} is ${(result === true ? 'enabled' : 'disabled')}`);
55
- }
56
- else {
57
- await logger.logToStderr(result);
58
- }
53
+ const result = json[json.length - 1];
54
+ if (this.verbose) {
55
+ await logger.logToStderr(`${cdnType === 0 ? 'Public' : 'Private'} CDN at ${spoAdminUrl} is ${result === true ? 'enabled' : 'disabled'}`);
59
56
  }
57
+ await logger.log(result);
60
58
  }
61
59
  catch (err) {
62
60
  this.handleRejectedPromise(err);
@@ -72,18 +70,17 @@ _SpoCdnGetCommand_instances = new WeakSet(), _SpoCdnGetCommand_initTelemetry = f
72
70
  }, _SpoCdnGetCommand_initOptions = function _SpoCdnGetCommand_initOptions() {
73
71
  this.options.unshift({
74
72
  option: '-t, --type [type]',
75
- autocomplete: ['Public', 'Private']
73
+ autocomplete: this.validTypes
76
74
  });
77
75
  }, _SpoCdnGetCommand_initValidators = function _SpoCdnGetCommand_initValidators() {
78
76
  this.validators.push(async (args) => {
79
- if (args.options.type) {
80
- if (args.options.type !== 'Public' &&
81
- args.options.type !== 'Private') {
82
- return `${args.options.type} is not a valid CDN type. Allowed values are Public|Private`;
83
- }
77
+ if (args.options.type && !this.validTypes.includes(args.options.type)) {
78
+ return `'${args.options.type}' is not a valid CDN type. Allowed values are: ${this.validTypes.join(', ')}.`;
84
79
  }
85
80
  return true;
86
81
  });
82
+ }, _SpoCdnGetCommand_initTypes = function _SpoCdnGetCommand_initTypes() {
83
+ this.types.string.push('type');
87
84
  };
88
85
  export default new SpoCdnGetCommand();
89
86
  //# sourceMappingURL=cdn-get.js.map