@pnp/cli-microsoft365 6.3.0-beta.655c566 → 6.3.0-beta.82f99fc

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 (55) hide show
  1. package/dist/cli/Cli.js +38 -0
  2. package/dist/m365/aad/commands/user/user-recyclebinitem-clear.js +103 -0
  3. package/dist/m365/aad/commands/user/user-recyclebinitem-remove.js +92 -0
  4. package/dist/m365/aad/commands.js +2 -0
  5. package/dist/m365/flow/commands/environment/FlowEnvironmentDetails.js +3 -0
  6. package/dist/m365/flow/commands/environment/environment-get.js +26 -11
  7. package/dist/m365/pa/commands/environment/environment-get.js +13 -5
  8. package/dist/m365/planner/commands/plan/plan-get.js +17 -10
  9. package/dist/m365/planner/commands/plan/plan-remove.js +1 -1
  10. package/dist/m365/planner/commands/roster/roster-member-remove.js +140 -0
  11. package/dist/m365/planner/commands.js +1 -0
  12. package/dist/m365/pp/commands/environment/environment-get.js +18 -9
  13. package/dist/m365/purview/commands/retentionevent/retentionevent-get.js +3 -4
  14. package/dist/m365/purview/commands/retentionevent/retentionevent-list.js +3 -4
  15. package/dist/m365/purview/commands/retentionevent/retentionevent-remove.js +97 -0
  16. package/dist/m365/purview/commands/retentioneventtype/retentioneventtype-get.js +5 -0
  17. package/dist/m365/purview/commands/retentioneventtype/retentioneventtype-list.js +3 -4
  18. package/dist/m365/purview/commands/retentionlabel/retentionlabel-add.js +5 -0
  19. package/dist/m365/purview/commands/retentionlabel/retentionlabel-get.js +5 -0
  20. package/dist/m365/purview/commands/retentionlabel/retentionlabel-list.js +5 -0
  21. package/dist/m365/purview/commands/retentionlabel/retentionlabel-remove.js +5 -0
  22. package/dist/m365/purview/commands/retentionlabel/retentionlabel-set.js +11 -1
  23. package/dist/m365/purview/commands.js +1 -0
  24. package/dist/m365/spo/commands/customaction/customaction-get.js +17 -66
  25. package/dist/m365/spo/commands/customaction/customaction-list.js +2 -36
  26. package/dist/m365/spo/commands/customaction/customaction-remove.js +11 -18
  27. package/dist/utils/aadUser.js +38 -0
  28. package/dist/utils/planner.js +1 -4
  29. package/dist/utils/spo.js +61 -0
  30. package/docs/docs/cmd/aad/user/user-recyclebinitem-clear.md +42 -0
  31. package/docs/docs/cmd/aad/user/user-recyclebinitem-remove.md +45 -0
  32. package/docs/docs/cmd/flow/environment/environment-get.md +31 -3
  33. package/docs/docs/cmd/login.md +26 -0
  34. package/docs/docs/cmd/logout.md +4 -0
  35. package/docs/docs/cmd/pa/environment/environment-get.md +8 -2
  36. package/docs/docs/cmd/planner/plan/plan-get.md +12 -12
  37. package/docs/docs/cmd/planner/roster/roster-member-remove.md +51 -0
  38. package/docs/docs/cmd/purview/retentionevent/retentionevent-list.md +1 -1
  39. package/docs/docs/cmd/purview/retentionevent/retentionevent-remove.md +45 -0
  40. package/docs/docs/cmd/purview/retentioneventtype/retentioneventtype-get.md +3 -0
  41. package/docs/docs/cmd/purview/retentioneventtype/retentioneventtype-list.md +1 -1
  42. package/docs/docs/cmd/purview/retentionlabel/retentionlabel-add.md +3 -0
  43. package/docs/docs/cmd/purview/retentionlabel/retentionlabel-get.md +3 -0
  44. package/docs/docs/cmd/purview/retentionlabel/retentionlabel-list.md +3 -0
  45. package/docs/docs/cmd/purview/retentionlabel/retentionlabel-remove.md +3 -0
  46. package/docs/docs/cmd/purview/retentionlabel/retentionlabel-set.md +3 -0
  47. package/docs/docs/cmd/request.md +74 -0
  48. package/docs/docs/cmd/spo/list/list-contenttype-add.md +1 -1
  49. package/docs/docs/cmd/spo/list/list-contenttype-default-set.md +1 -1
  50. package/docs/docs/cmd/spo/list/list-contenttype-list.md +1 -1
  51. package/docs/docs/cmd/spo/list/list-contenttype-remove.md +1 -1
  52. package/docs/docs/cmd/status.md +46 -0
  53. package/docs/docs/cmd/version.md +26 -0
  54. package/npm-shrinkwrap.json +911 -876
  55. package/package.json +12 -12
package/dist/cli/Cli.js CHANGED
@@ -118,6 +118,8 @@ class Cli {
118
118
  }
119
119
  try {
120
120
  // process options before passing them on to validation stage
121
+ const contextCommandOptions = this.loadOptionsFromContext(this.commandToExecute.options, optionsWithoutShorts.options.debug);
122
+ optionsWithoutShorts.options = Object.assign(Object.assign({}, contextCommandOptions), optionsWithoutShorts.options);
121
123
  yield this.commandToExecute.command.processOptions(optionsWithoutShorts.options);
122
124
  }
123
125
  catch (e) {
@@ -283,6 +285,42 @@ class Cli {
283
285
  }
284
286
  this.loadCommandFromFile(commandFilePath);
285
287
  }
288
+ loadOptionsFromContext(commandOptions, debug) {
289
+ const filePath = '.m365rc.json';
290
+ let m365rc = {};
291
+ if (!fs.existsSync(filePath)) {
292
+ return;
293
+ }
294
+ if (debug) {
295
+ Cli.error('found .m365rc.json file');
296
+ }
297
+ try {
298
+ const fileContents = fs.readFileSync(filePath, 'utf8');
299
+ if (fileContents) {
300
+ m365rc = JSON.parse(fileContents);
301
+ }
302
+ }
303
+ catch (e) {
304
+ this.closeWithError(`Error parsing ${filePath}`, { options: {} });
305
+ }
306
+ if (!m365rc.context) {
307
+ return;
308
+ }
309
+ if (debug) {
310
+ Cli.error('found context in .m365rc.json file');
311
+ }
312
+ const context = m365rc.context;
313
+ const foundOptions = {};
314
+ commandOptions.forEach(option => {
315
+ if (context[option.name]) {
316
+ foundOptions[option.name] = context[option.name];
317
+ if (debug) {
318
+ Cli.error(`returning ${option.name} option from context`);
319
+ }
320
+ }
321
+ });
322
+ return foundOptions;
323
+ }
286
324
  /**
287
325
  * Loads command from the specified file into CLI. If can't find the file
288
326
  * or the file doesn't contain a command, loads all available commands.
@@ -0,0 +1,103 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
12
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
13
+ 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");
14
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
15
+ };
16
+ var _AadUserRecycleBinItemClearCommand_instances, _AadUserRecycleBinItemClearCommand_initTelemetry, _AadUserRecycleBinItemClearCommand_initOptions;
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ const Cli_1 = require("../../../../cli/Cli");
19
+ const request_1 = require("../../../../request");
20
+ const odata_1 = require("../../../../utils/odata");
21
+ const GraphCommand_1 = require("../../../base/GraphCommand");
22
+ const commands_1 = require("../../commands");
23
+ class AadUserRecycleBinItemClearCommand extends GraphCommand_1.default {
24
+ get name() {
25
+ return commands_1.default.USER_RECYCLEBINITEM_CLEAR;
26
+ }
27
+ get description() {
28
+ return 'Removes all users from the tenant recycle bin';
29
+ }
30
+ constructor() {
31
+ super();
32
+ _AadUserRecycleBinItemClearCommand_instances.add(this);
33
+ __classPrivateFieldGet(this, _AadUserRecycleBinItemClearCommand_instances, "m", _AadUserRecycleBinItemClearCommand_initTelemetry).call(this);
34
+ __classPrivateFieldGet(this, _AadUserRecycleBinItemClearCommand_instances, "m", _AadUserRecycleBinItemClearCommand_initOptions).call(this);
35
+ }
36
+ commandAction(logger, args) {
37
+ return __awaiter(this, void 0, void 0, function* () {
38
+ const clearRecycleBinUsers = () => __awaiter(this, void 0, void 0, function* () {
39
+ try {
40
+ const users = yield odata_1.odata.getAllItems(`${this.resource}/v1.0/directory/deletedItems/microsoft.graph.user?$select=id`);
41
+ if (this.verbose) {
42
+ logger.logToStderr(`Amount of users to permanently delete: ${users.length}`);
43
+ }
44
+ const batchRequests = users.map((user, index) => {
45
+ return {
46
+ id: index,
47
+ method: 'DELETE',
48
+ url: `/directory/deletedItems/${user.id}`
49
+ };
50
+ });
51
+ for (let i = 0; i < batchRequests.length; i += 20) {
52
+ const batchRequestChunk = batchRequests.slice(i, i + 20);
53
+ if (this.verbose) {
54
+ logger.logToStderr(`Deleting users: ${i + batchRequestChunk.length}/${users.length}`);
55
+ }
56
+ const requestOptions = {
57
+ url: `${this.resource}/v1.0/$batch`,
58
+ headers: {
59
+ accept: 'application/json',
60
+ 'content-type': 'application/json'
61
+ },
62
+ responseType: 'json',
63
+ data: {
64
+ requests: batchRequestChunk
65
+ }
66
+ };
67
+ yield request_1.default.post(requestOptions);
68
+ }
69
+ }
70
+ catch (err) {
71
+ this.handleRejectedODataJsonPromise(err);
72
+ }
73
+ });
74
+ if (args.options.confirm) {
75
+ yield clearRecycleBinUsers();
76
+ }
77
+ else {
78
+ const result = yield Cli_1.Cli.prompt({
79
+ type: 'confirm',
80
+ name: 'continue',
81
+ default: false,
82
+ message: 'Are you sure you want to permanently delete all deleted users?'
83
+ });
84
+ if (result.continue) {
85
+ yield clearRecycleBinUsers();
86
+ }
87
+ }
88
+ });
89
+ }
90
+ }
91
+ _AadUserRecycleBinItemClearCommand_instances = new WeakSet(), _AadUserRecycleBinItemClearCommand_initTelemetry = function _AadUserRecycleBinItemClearCommand_initTelemetry() {
92
+ this.telemetry.push((args) => {
93
+ Object.assign(this.telemetryProperties, {
94
+ confirm: !!args.options.confirm
95
+ });
96
+ });
97
+ }, _AadUserRecycleBinItemClearCommand_initOptions = function _AadUserRecycleBinItemClearCommand_initOptions() {
98
+ this.options.unshift({
99
+ option: '--confirm'
100
+ });
101
+ };
102
+ module.exports = new AadUserRecycleBinItemClearCommand();
103
+ //# sourceMappingURL=user-recyclebinitem-clear.js.map
@@ -0,0 +1,92 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
12
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
13
+ 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");
14
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
15
+ };
16
+ var _AadUserRecycleBinItemRemoveCommand_instances, _AadUserRecycleBinItemRemoveCommand_initTelemetry, _AadUserRecycleBinItemRemoveCommand_initOptions, _AadUserRecycleBinItemRemoveCommand_initValidators;
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ const Cli_1 = require("../../../../cli/Cli");
19
+ const request_1 = require("../../../../request");
20
+ const validation_1 = require("../../../../utils/validation");
21
+ const GraphCommand_1 = require("../../../base/GraphCommand");
22
+ const commands_1 = require("../../commands");
23
+ class AadUserRecycleBinItemRemoveCommand extends GraphCommand_1.default {
24
+ get name() {
25
+ return commands_1.default.USER_RECYCLEBINITEM_REMOVE;
26
+ }
27
+ get description() {
28
+ return 'Removes a user from the recycle bin in the current tenant';
29
+ }
30
+ constructor() {
31
+ super();
32
+ _AadUserRecycleBinItemRemoveCommand_instances.add(this);
33
+ __classPrivateFieldGet(this, _AadUserRecycleBinItemRemoveCommand_instances, "m", _AadUserRecycleBinItemRemoveCommand_initTelemetry).call(this);
34
+ __classPrivateFieldGet(this, _AadUserRecycleBinItemRemoveCommand_instances, "m", _AadUserRecycleBinItemRemoveCommand_initOptions).call(this);
35
+ __classPrivateFieldGet(this, _AadUserRecycleBinItemRemoveCommand_instances, "m", _AadUserRecycleBinItemRemoveCommand_initValidators).call(this);
36
+ }
37
+ commandAction(logger, args) {
38
+ return __awaiter(this, void 0, void 0, function* () {
39
+ const clearRecycleBinItem = () => __awaiter(this, void 0, void 0, function* () {
40
+ if (this.verbose) {
41
+ logger.logToStderr(`Permanently deleting user with id ${args.options.id} from Azure Active Directory`);
42
+ }
43
+ try {
44
+ const requestOptions = {
45
+ url: `${this.resource}/v1.0/directory/deletedItems/${args.options.id}`,
46
+ headers: {}
47
+ };
48
+ yield request_1.default.delete(requestOptions);
49
+ }
50
+ catch (err) {
51
+ this.handleRejectedODataJsonPromise(err);
52
+ }
53
+ });
54
+ if (args.options.confirm) {
55
+ yield clearRecycleBinItem();
56
+ }
57
+ else {
58
+ const result = yield Cli_1.Cli.prompt({
59
+ type: 'confirm',
60
+ name: 'continue',
61
+ default: false,
62
+ message: `Are you sure you want to permanently delete the user with id ${args.options.id}?`
63
+ });
64
+ if (result.continue) {
65
+ yield clearRecycleBinItem();
66
+ }
67
+ }
68
+ });
69
+ }
70
+ }
71
+ _AadUserRecycleBinItemRemoveCommand_instances = new WeakSet(), _AadUserRecycleBinItemRemoveCommand_initTelemetry = function _AadUserRecycleBinItemRemoveCommand_initTelemetry() {
72
+ this.telemetry.push((args) => {
73
+ Object.assign(this.telemetryProperties, {
74
+ confirm: !!args.options.confirm
75
+ });
76
+ });
77
+ }, _AadUserRecycleBinItemRemoveCommand_initOptions = function _AadUserRecycleBinItemRemoveCommand_initOptions() {
78
+ this.options.unshift({
79
+ option: '--id <id>'
80
+ }, {
81
+ option: '--confirm'
82
+ });
83
+ }, _AadUserRecycleBinItemRemoveCommand_initValidators = function _AadUserRecycleBinItemRemoveCommand_initValidators() {
84
+ this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
85
+ if (args.options.id && !validation_1.validation.isValidGuid(args.options.id)) {
86
+ return `${args.options.id} is not a valid GUID`;
87
+ }
88
+ return true;
89
+ }));
90
+ };
91
+ module.exports = new AadUserRecycleBinItemRemoveCommand();
92
+ //# sourceMappingURL=user-recyclebinitem-remove.js.map
@@ -60,6 +60,8 @@ exports.default = {
60
60
  USER_HIBP: `${prefix} user hibp`,
61
61
  USER_LIST: `${prefix} user list`,
62
62
  USER_PASSWORD_VALIDATE: `${prefix} user password validate`,
63
+ USER_RECYCLEBINITEM_CLEAR: `${prefix} user recyclebinitem clear`,
64
+ USER_RECYCLEBINITEM_REMOVE: `${prefix} user recyclebinitem remove`,
63
65
  USER_SET: `${prefix} user set`,
64
66
  USER_SIGNIN_LIST: `${prefix} user signin list`
65
67
  };
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=FlowEnvironmentDetails.js.map
@@ -13,7 +13,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
13
13
  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");
14
14
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
15
15
  };
16
- var _FlowEnvironmentGetCommand_instances, _FlowEnvironmentGetCommand_initOptions;
16
+ var _FlowEnvironmentGetCommand_instances, _FlowEnvironmentGetCommand_initOptions, _FlowEnvironmentGetCommand_initTelemetry;
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const request_1 = require("../../../../request");
19
19
  const formatting_1 = require("../../../../utils/formatting");
@@ -33,27 +33,36 @@ class FlowEnvironmentGetCommand extends AzmgmtCommand_1.default {
33
33
  super();
34
34
  _FlowEnvironmentGetCommand_instances.add(this);
35
35
  __classPrivateFieldGet(this, _FlowEnvironmentGetCommand_instances, "m", _FlowEnvironmentGetCommand_initOptions).call(this);
36
+ __classPrivateFieldGet(this, _FlowEnvironmentGetCommand_instances, "m", _FlowEnvironmentGetCommand_initTelemetry).call(this);
36
37
  }
37
38
  commandAction(logger, args) {
39
+ var _a;
38
40
  return __awaiter(this, void 0, void 0, function* () {
39
41
  if (this.verbose) {
40
- logger.logToStderr(`Retrieving information about Microsoft Flow environment ${args.options.name}...`);
42
+ logger.logToStderr(`Retrieving information about Microsoft Flow environment ${(_a = args.options.name) !== null && _a !== void 0 ? _a : ''}...`);
43
+ }
44
+ let requestUrl = `${this.resource}providers/Microsoft.ProcessSimple/environments/`;
45
+ if (args.options.name) {
46
+ requestUrl += `${formatting_1.formatting.encodeQueryParameter(args.options.name)}`;
47
+ }
48
+ else {
49
+ requestUrl += `~default`;
41
50
  }
42
51
  const requestOptions = {
43
- url: `${this.resource}providers/Microsoft.ProcessSimple/environments/${formatting_1.formatting.encodeQueryParameter(args.options.name)}?api-version=2016-11-01`,
52
+ url: `${requestUrl}?api-version=2016-11-01`,
44
53
  headers: {
45
54
  accept: 'application/json'
46
55
  },
47
56
  responseType: 'json'
48
57
  };
49
58
  try {
50
- const res = yield request_1.default.get(requestOptions);
51
- res.displayName = res.properties.displayName;
52
- res.provisioningState = res.properties.provisioningState;
53
- res.environmentSku = res.properties.environmentSku;
54
- res.azureRegionHint = res.properties.azureRegionHint;
55
- res.isDefault = res.properties.isDefault;
56
- logger.log(res);
59
+ const flowItem = yield request_1.default.get(requestOptions);
60
+ flowItem.displayName = flowItem.properties.displayName;
61
+ flowItem.provisioningState = flowItem.properties.provisioningState;
62
+ flowItem.environmentSku = flowItem.properties.environmentSku;
63
+ flowItem.azureRegionHint = flowItem.properties.azureRegionHint;
64
+ flowItem.isDefault = flowItem.properties.isDefault;
65
+ logger.log(flowItem);
57
66
  }
58
67
  catch (err) {
59
68
  this.handleRejectedODataJsonPromise(err);
@@ -63,7 +72,13 @@ class FlowEnvironmentGetCommand extends AzmgmtCommand_1.default {
63
72
  }
64
73
  _FlowEnvironmentGetCommand_instances = new WeakSet(), _FlowEnvironmentGetCommand_initOptions = function _FlowEnvironmentGetCommand_initOptions() {
65
74
  this.options.unshift({
66
- option: '-n, --name <name>'
75
+ option: '-n, --name [name]'
76
+ });
77
+ }, _FlowEnvironmentGetCommand_initTelemetry = function _FlowEnvironmentGetCommand_initTelemetry() {
78
+ this.telemetry.push((args) => {
79
+ Object.assign(this.telemetryProperties, {
80
+ name: typeof args.options.name !== 'undefined'
81
+ });
67
82
  });
68
83
  };
69
84
  module.exports = new FlowEnvironmentGetCommand();
@@ -13,7 +13,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
13
13
  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");
14
14
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
15
15
  };
16
- var _PaEnvironmentGetCommand_instances, _PaEnvironmentGetCommand_initOptions;
16
+ var _PaEnvironmentGetCommand_instances, _PaEnvironmentGetCommand_initTelemetry, _PaEnvironmentGetCommand_initOptions;
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const request_1 = require("../../../../request");
19
19
  const formatting_1 = require("../../../../utils/formatting");
@@ -32,15 +32,17 @@ class PaEnvironmentGetCommand extends PowerAppsCommand_1.default {
32
32
  constructor() {
33
33
  super();
34
34
  _PaEnvironmentGetCommand_instances.add(this);
35
+ __classPrivateFieldGet(this, _PaEnvironmentGetCommand_instances, "m", _PaEnvironmentGetCommand_initTelemetry).call(this);
35
36
  __classPrivateFieldGet(this, _PaEnvironmentGetCommand_instances, "m", _PaEnvironmentGetCommand_initOptions).call(this);
36
37
  }
37
38
  commandAction(logger, args) {
38
39
  return __awaiter(this, void 0, void 0, function* () {
39
40
  if (this.verbose) {
40
- logger.logToStderr(`Retrieving information about Microsoft Power Apps environment ${args.options.name}...`);
41
+ logger.logToStderr(`Retrieving information about Microsoft Power Apps environment ${args.options.name || 'default'}...`);
41
42
  }
43
+ const environmentName = args.options.name ? formatting_1.formatting.encodeQueryParameter(args.options.name) : '~default';
42
44
  const requestOptions = {
43
- url: `${this.resource}/providers/Microsoft.PowerApps/environments/${formatting_1.formatting.encodeQueryParameter(args.options.name)}?api-version=2016-11-01`,
45
+ url: `${this.resource}/providers/Microsoft.PowerApps/environments/${environmentName}?api-version=2016-11-01`,
44
46
  headers: {
45
47
  accept: 'application/json'
46
48
  },
@@ -61,9 +63,15 @@ class PaEnvironmentGetCommand extends PowerAppsCommand_1.default {
61
63
  });
62
64
  }
63
65
  }
64
- _PaEnvironmentGetCommand_instances = new WeakSet(), _PaEnvironmentGetCommand_initOptions = function _PaEnvironmentGetCommand_initOptions() {
66
+ _PaEnvironmentGetCommand_instances = new WeakSet(), _PaEnvironmentGetCommand_initTelemetry = function _PaEnvironmentGetCommand_initTelemetry() {
67
+ this.telemetry.push((args) => {
68
+ Object.assign(this.telemetryProperties, {
69
+ name: typeof args.options.name !== 'undefined'
70
+ });
71
+ });
72
+ }, _PaEnvironmentGetCommand_initOptions = function _PaEnvironmentGetCommand_initOptions() {
65
73
  this.options.unshift({
66
- option: '-n, --name <name>'
74
+ option: '-n, --name [name]'
67
75
  });
68
76
  };
69
77
  module.exports = new PaEnvironmentGetCommand();
@@ -48,11 +48,18 @@ class PlannerPlanGetCommand extends GraphCommand_1.default {
48
48
  logger.log(result);
49
49
  }
50
50
  else {
51
- let groupId = undefined;
52
- if (args.options.ownerGroupId || args.options.ownerGroupName) {
53
- groupId = yield this.getGroupId(args);
51
+ let plan = {};
52
+ if (args.options.rosterId) {
53
+ const plans = yield planner_1.planner.getPlansByRosterId(args.options.rosterId);
54
+ plan = plans[0];
55
+ }
56
+ else {
57
+ let groupId = undefined;
58
+ if (args.options.ownerGroupId || args.options.ownerGroupName) {
59
+ groupId = yield this.getGroupId(args);
60
+ }
61
+ plan = yield planner_1.planner.getPlanByTitle(args.options.title, groupId);
54
62
  }
55
- const plan = yield planner_1.planner.getPlanByTitle(args.options.title, groupId, args.options.rosterId);
56
63
  const result = yield this.getPlanDetails(plan);
57
64
  if (result) {
58
65
  logger.log(result);
@@ -93,9 +100,9 @@ _PlannerPlanGetCommand_instances = new WeakSet(), _PlannerPlanGetCommand_initTel
93
100
  Object.assign(this.telemetryProperties, {
94
101
  id: typeof args.options.id !== 'undefined',
95
102
  title: typeof args.options.title !== 'undefined',
103
+ rosterId: typeof args.options.rosterId !== 'undefined',
96
104
  ownerGroupId: typeof args.options.ownerGroupId !== 'undefined',
97
- ownerGroupName: typeof args.options.ownerGroupName !== 'undefined',
98
- rosterId: typeof args.options.rosterId !== 'undefined'
105
+ ownerGroupName: typeof args.options.ownerGroupName !== 'undefined'
99
106
  });
100
107
  });
101
108
  }, _PlannerPlanGetCommand_initOptions = function _PlannerPlanGetCommand_initOptions() {
@@ -103,12 +110,12 @@ _PlannerPlanGetCommand_instances = new WeakSet(), _PlannerPlanGetCommand_initTel
103
110
  option: '-i, --id [id]'
104
111
  }, {
105
112
  option: '-t, --title [title]'
113
+ }, {
114
+ option: '--rosterId [rosterId]'
106
115
  }, {
107
116
  option: '--ownerGroupId [ownerGroupId]'
108
117
  }, {
109
118
  option: '--ownerGroupName [ownerGroupName]'
110
- }, {
111
- option: '--rosterId [rosterId]'
112
119
  });
113
120
  }, _PlannerPlanGetCommand_initValidators = function _PlannerPlanGetCommand_initValidators() {
114
121
  this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
@@ -119,9 +126,9 @@ _PlannerPlanGetCommand_instances = new WeakSet(), _PlannerPlanGetCommand_initTel
119
126
  }));
120
127
  }, _PlannerPlanGetCommand_initOptionSets = function _PlannerPlanGetCommand_initOptionSets() {
121
128
  this.optionSets.push({
122
- options: ['id', 'title']
129
+ options: ['id', 'title', 'rosterId']
123
130
  }, {
124
- options: ['ownerGroupId', 'ownerGroupName', 'rosterId'],
131
+ options: ['ownerGroupId', 'ownerGroupName'],
125
132
  runsWhen: (args) => {
126
133
  return args.options.title !== undefined;
127
134
  }
@@ -79,7 +79,7 @@ class PlannerPlanRemoveCommand extends GraphCommand_1.default {
79
79
  return planner_1.planner.getPlanById(id, 'minimal');
80
80
  }
81
81
  const groupId = yield this.getGroupId(args);
82
- return yield planner_1.planner.getPlanByTitle(title, groupId, undefined, 'minimal');
82
+ return yield planner_1.planner.getPlanByTitle(title, groupId, 'minimal');
83
83
  });
84
84
  }
85
85
  getGroupId(args) {
@@ -0,0 +1,140 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
12
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
13
+ 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");
14
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
15
+ };
16
+ var _PlannerRosterMemberRemoveCommand_instances, _PlannerRosterMemberRemoveCommand_initTelemetry, _PlannerRosterMemberRemoveCommand_initOptions, _PlannerRosterMemberRemoveCommand_initOptionSets, _PlannerRosterMemberRemoveCommand_initValidators;
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ const Cli_1 = require("../../../../cli/Cli");
19
+ const request_1 = require("../../../../request");
20
+ const validation_1 = require("../../../../utils/validation");
21
+ const GraphCommand_1 = require("../../../base/GraphCommand");
22
+ const commands_1 = require("../../commands");
23
+ const odata_1 = require("../../../../utils/odata");
24
+ const aadUser_1 = require("../../../../utils/aadUser");
25
+ class PlannerRosterMemberRemoveCommand extends GraphCommand_1.default {
26
+ get name() {
27
+ return commands_1.default.ROSTER_MEMBER_REMOVE;
28
+ }
29
+ get description() {
30
+ return 'Removes a member from a Microsoft Planner Roster';
31
+ }
32
+ constructor() {
33
+ super();
34
+ _PlannerRosterMemberRemoveCommand_instances.add(this);
35
+ __classPrivateFieldGet(this, _PlannerRosterMemberRemoveCommand_instances, "m", _PlannerRosterMemberRemoveCommand_initTelemetry).call(this);
36
+ __classPrivateFieldGet(this, _PlannerRosterMemberRemoveCommand_instances, "m", _PlannerRosterMemberRemoveCommand_initOptions).call(this);
37
+ __classPrivateFieldGet(this, _PlannerRosterMemberRemoveCommand_instances, "m", _PlannerRosterMemberRemoveCommand_initValidators).call(this);
38
+ __classPrivateFieldGet(this, _PlannerRosterMemberRemoveCommand_instances, "m", _PlannerRosterMemberRemoveCommand_initOptionSets).call(this);
39
+ }
40
+ commandAction(logger, args) {
41
+ return __awaiter(this, void 0, void 0, function* () {
42
+ if (this.verbose) {
43
+ logger.logToStderr(`Removing member ${args.options.userName || args.options.userId} from the Microsoft Planner Roster`);
44
+ }
45
+ if (args.options.confirm) {
46
+ yield this.removeRosterMember(args);
47
+ }
48
+ else {
49
+ const result = yield Cli_1.Cli.prompt({
50
+ type: 'confirm',
51
+ name: 'continue',
52
+ default: false,
53
+ message: `Are you sure you want to remove member '${args.options.userId || args.options.userName}'?`
54
+ });
55
+ if (result.continue) {
56
+ yield this.removeRosterMember(args);
57
+ }
58
+ }
59
+ });
60
+ }
61
+ getUserId(args) {
62
+ return __awaiter(this, void 0, void 0, function* () {
63
+ if (args.options.userId) {
64
+ return args.options.userId;
65
+ }
66
+ return aadUser_1.aadUser.getUserIdByUpn(args.options.userName);
67
+ });
68
+ }
69
+ removeRosterMember(args) {
70
+ return __awaiter(this, void 0, void 0, function* () {
71
+ try {
72
+ const rosterMembersContinue = yield this.removeLastMemberConfirmation(args);
73
+ if (rosterMembersContinue) {
74
+ const userId = yield this.getUserId(args);
75
+ const requestOptions = {
76
+ url: `${this.resource}/beta/planner/rosters/${args.options.rosterId}/members/${userId}`,
77
+ headers: {
78
+ accept: 'application/json;odata.metadata=none'
79
+ },
80
+ responseType: 'json'
81
+ };
82
+ yield request_1.default.delete(requestOptions);
83
+ }
84
+ }
85
+ catch (err) {
86
+ this.handleRejectedODataJsonPromise(err);
87
+ }
88
+ });
89
+ }
90
+ removeLastMemberConfirmation(args) {
91
+ return __awaiter(this, void 0, void 0, function* () {
92
+ if (!args.options.confirm) {
93
+ const rosterMembers = yield odata_1.odata.getAllItems(`${this.resource}/beta/planner/rosters/${args.options.rosterId}/members?$select=Id`);
94
+ if (rosterMembers.length === 1) {
95
+ const result = yield Cli_1.Cli.prompt({
96
+ type: 'confirm',
97
+ name: 'continue',
98
+ default: false,
99
+ message: `You are about to remove the last member of this Roster. When this happens, the Roster and all its contents will be deleted within 30 days. Are you sure you want to proceed?`
100
+ });
101
+ return result.continue;
102
+ }
103
+ }
104
+ return true;
105
+ });
106
+ }
107
+ }
108
+ _PlannerRosterMemberRemoveCommand_instances = new WeakSet(), _PlannerRosterMemberRemoveCommand_initTelemetry = function _PlannerRosterMemberRemoveCommand_initTelemetry() {
109
+ this.telemetry.push((args) => {
110
+ Object.assign(this.telemetryProperties, {
111
+ userId: typeof args.options.userId !== 'undefined',
112
+ userName: typeof args.options.userName !== 'undefined',
113
+ confirm: !!args.options.confirm
114
+ });
115
+ });
116
+ }, _PlannerRosterMemberRemoveCommand_initOptions = function _PlannerRosterMemberRemoveCommand_initOptions() {
117
+ this.options.unshift({
118
+ option: '--rosterId <rosterId>'
119
+ }, {
120
+ option: '--userId [userId]'
121
+ }, {
122
+ option: '--userName [userName]'
123
+ }, {
124
+ option: '--confirm'
125
+ });
126
+ }, _PlannerRosterMemberRemoveCommand_initOptionSets = function _PlannerRosterMemberRemoveCommand_initOptionSets() {
127
+ this.optionSets.push({ options: ['userId', 'userName'] });
128
+ }, _PlannerRosterMemberRemoveCommand_initValidators = function _PlannerRosterMemberRemoveCommand_initValidators() {
129
+ this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
130
+ if (args.options.userId && !validation_1.validation.isValidGuid(args.options.userId)) {
131
+ return `${args.options.userId} is not a valid GUID`;
132
+ }
133
+ if (args.options.userName && !validation_1.validation.isValidUserPrincipalName(args.options.userName)) {
134
+ return `${args.options.userName} is not a valid userName`;
135
+ }
136
+ return true;
137
+ }));
138
+ };
139
+ module.exports = new PlannerRosterMemberRemoveCommand();
140
+ //# sourceMappingURL=roster-member-remove.js.map
@@ -16,6 +16,7 @@ exports.default = {
16
16
  ROSTER_GET: `${prefix} roster get`,
17
17
  ROSTER_MEMBER_ADD: `${prefix} roster member add`,
18
18
  ROSTER_MEMBER_LIST: `${prefix} roster member list`,
19
+ ROSTER_MEMBER_REMOVE: `${prefix} roster member remove`,
19
20
  ROSTER_REMOVE: `${prefix} roster remove`,
20
21
  TASK_ADD: `${prefix} task add`,
21
22
  TASK_CHECKLISTITEM_ADD: `${prefix} task checklistitem add`,
@@ -15,9 +15,10 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
15
15
  };
16
16
  var _PpEnvironmentGetCommand_instances, _PpEnvironmentGetCommand_initTelemetry, _PpEnvironmentGetCommand_initOptions;
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
- const odata_1 = require("../../../../utils/odata");
19
18
  const PowerPlatformCommand_1 = require("../../../base/PowerPlatformCommand");
20
19
  const commands_1 = require("../../commands");
20
+ const request_1 = require("../../../../request");
21
+ const formatting_1 = require("../../../../utils/formatting");
21
22
  class PpEnvironmentGetCommand extends PowerPlatformCommand_1.default {
22
23
  get name() {
23
24
  return commands_1.default.ENVIRONMENT_GET;
@@ -36,16 +37,24 @@ class PpEnvironmentGetCommand extends PowerPlatformCommand_1.default {
36
37
  }
37
38
  commandAction(logger, args) {
38
39
  return __awaiter(this, void 0, void 0, function* () {
39
- let url = `${this.resource}/providers/Microsoft.BusinessAppPlatform/environments`;
40
- if (args.options.asAdmin) {
41
- url = `${this.resource}/providers/Microsoft.BusinessAppPlatform/scopes/admin/environments`;
40
+ if (this.verbose) {
41
+ logger.logToStderr(`Retrieving environment: ${args.options.name || 'default'}`);
42
42
  }
43
- const res = yield odata_1.odata.getAllItems(`${url}?api-version=2020-10-01`);
44
- const environmentItem = res.filter((env) => args.options.name ? env.name === args.options.name : env.properties.isDefault === true)[0];
45
- if (!environmentItem) {
46
- throw `The specified Power Platform environment does not exist`;
43
+ let url = `${this.resource}/providers/Microsoft.BusinessAppPlatform`;
44
+ if (args.options.asAdmin) {
45
+ url += '/scopes/admin';
47
46
  }
48
- logger.log(environmentItem);
47
+ const envName = args.options.name ? formatting_1.formatting.encodeQueryParameter(args.options.name) : '~Default';
48
+ url += `/environments/${envName}?api-version=2020-10-01`;
49
+ const requestOptions = {
50
+ url: url,
51
+ headers: {
52
+ accept: 'application/json;odata.metadata=none'
53
+ },
54
+ responseType: 'json'
55
+ };
56
+ const response = yield request_1.default.get(requestOptions);
57
+ logger.log(response);
49
58
  });
50
59
  }
51
60
  }