@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.
- package/allCommands.json +1 -1
- package/allCommandsFull.json +1 -1
- package/dist/Auth.js +1 -9
- package/dist/chili/chili.js +0 -23
- package/dist/cli/cli.js +1 -63
- package/dist/m365/commands/setup.js +0 -4
- package/dist/m365/external/commands/connection/connection-doctor.js +10 -24
- package/dist/m365/flow/commands/flow-list.js +21 -23
- package/dist/m365/spfx/commands/project/base-project-command.js +36 -126
- package/dist/m365/spo/commands/cdn/cdn-get.js +12 -15
- package/dist/m365/spo/commands/cdn/cdn-set.js +6 -4
- package/dist/m365/spo/commands/contenttype/contenttype-field-list.js +124 -0
- package/dist/m365/spo/commands/field/field-list.js +1 -1
- package/dist/m365/spo/commands/group/group-member-add.js +103 -99
- package/dist/m365/spo/commands/page/page-clientsidewebpart-add.js +2 -3
- package/dist/m365/spo/commands/page/page-text-add.js +2 -3
- package/dist/m365/spo/commands/spo-search.js +3 -4
- package/dist/m365/spo/commands.js +1 -0
- package/dist/m365/teams/commands/meeting/meeting-attendancereport-get.js +119 -0
- package/dist/m365/teams/commands.js +1 -0
- package/dist/utils/formatting.js +14 -1
- package/dist/utils/validation.js +19 -0
- package/docs/docs/cmd/external/connection/connection-doctor.mdx +9 -9
- package/docs/docs/cmd/flow/flow-list.mdx +114 -56
- package/docs/docs/cmd/spo/cdn/cdn-set.mdx +3 -3
- package/docs/docs/cmd/spo/contenttype/contenttype-field-list.mdx +172 -0
- package/docs/docs/cmd/spo/field/field-list.mdx +3 -3
- package/docs/docs/cmd/spo/group/group-member-add.mdx +34 -27
- package/docs/docs/cmd/teams/meeting/meeting-attendancereport-get.mdx +138 -0
- package/npm-shrinkwrap.json +0 -195
- 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
|
-
|
|
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
|
}
|
package/dist/chili/chili.js
CHANGED
|
@@ -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
|
|
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
|
-
|
|
125
|
-
|
|
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
|
-
|
|
139
|
-
|
|
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
|
-
|
|
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
|
-
|
|
137
|
+
await logger.log(formatting.getStatus(CheckStatus.Failure, message));
|
|
152
138
|
}
|
|
153
139
|
else {
|
|
154
|
-
|
|
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 (
|
|
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
|
|
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 (
|
|
54
|
-
items.forEach(
|
|
55
|
-
|
|
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
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
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
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
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
|
-
|
|
145
|
-
|
|
146
|
-
|
|
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
|
-
|
|
52
|
-
|
|
53
|
-
|
|
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:
|
|
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
|
-
|
|
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
|