@pnp/cli-microsoft365 5.9.0-beta.c3fe008 → 5.9.0-beta.db8b86a

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 (33) hide show
  1. package/.eslintrc.js +4 -2
  2. package/dist/m365/outlook/commands/mail/mail-send.js +1 -1
  3. package/dist/m365/planner/commands/bucket/bucket-get.js +1 -1
  4. package/dist/m365/pp/commands/Environment.js +3 -0
  5. package/dist/m365/pp/commands/environment/environment-get.js +75 -0
  6. package/dist/m365/pp/commands.js +1 -0
  7. package/dist/m365/spo/commands/folder/folder-roleassignment-remove.js +168 -0
  8. package/dist/m365/spo/commands/list/list-contenttype-add.js +21 -18
  9. package/dist/m365/spo/commands/list/list-contenttype-default-set.js +59 -47
  10. package/dist/m365/spo/commands/list/list-contenttype-list.js +16 -8
  11. package/dist/m365/spo/commands/list/list-contenttype-remove.js +16 -8
  12. package/dist/m365/spo/commands/list/list-webhook-add.js +19 -11
  13. package/dist/m365/spo/commands/list/list-webhook-get.js +17 -9
  14. package/dist/m365/spo/commands/list/list-webhook-list.js +23 -24
  15. package/dist/m365/spo/commands/list/list-webhook-remove.js +19 -11
  16. package/dist/m365/spo/commands/list/list-webhook-set.js +18 -10
  17. package/dist/m365/spo/commands.js +1 -0
  18. package/dist/m365/todo/commands/task/task-set.js +53 -1
  19. package/docs/docs/cmd/pp/environment/environment-get.md +38 -0
  20. package/docs/docs/cmd/spo/eventreceiver/eventreceiver-get.md +2 -2
  21. package/docs/docs/cmd/spo/eventreceiver/eventreceiver-remove.md +2 -2
  22. package/docs/docs/cmd/spo/folder/folder-roleassignment-remove.md +57 -0
  23. package/docs/docs/cmd/spo/list/list-contenttype-add.md +16 -7
  24. package/docs/docs/cmd/spo/list/list-contenttype-default-set.md +16 -7
  25. package/docs/docs/cmd/spo/list/list-contenttype-list.md +15 -6
  26. package/docs/docs/cmd/spo/list/list-contenttype-remove.md +17 -8
  27. package/docs/docs/cmd/spo/list/list-webhook-add.md +15 -16
  28. package/docs/docs/cmd/spo/list/list-webhook-get.md +15 -6
  29. package/docs/docs/cmd/spo/list/list-webhook-list.md +16 -7
  30. package/docs/docs/cmd/spo/list/list-webhook-remove.md +12 -10
  31. package/docs/docs/cmd/spo/list/list-webhook-set.md +13 -11
  32. package/docs/docs/cmd/todo/task/task-set.md +29 -2
  33. package/package.json +2 -1
@@ -18,6 +18,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const Cli_1 = require("../../../../cli/Cli");
19
19
  const request_1 = require("../../../../request");
20
20
  const formatting_1 = require("../../../../utils/formatting");
21
+ const urlUtil_1 = require("../../../../utils/urlUtil");
21
22
  const validation_1 = require("../../../../utils/validation");
22
23
  const SpoCommand_1 = require("../../../base/SpoCommand");
23
24
  const commands_1 = require("../../commands");
@@ -41,18 +42,22 @@ class SpoListContentTypeRemoveCommand extends SpoCommand_1.default {
41
42
  return __awaiter(this, void 0, void 0, function* () {
42
43
  const removeContentTypeFromList = () => __awaiter(this, void 0, void 0, function* () {
43
44
  if (this.verbose) {
44
- const list = (args.options.listId ? args.options.listId : args.options.listTitle);
45
+ const list = (args.options.listId ? args.options.listId : args.options.listTitle ? args.options.listTitle : args.options.listUrl);
45
46
  logger.logToStderr(`Removing content type ${args.options.contentTypeId} from list ${list} in site at ${args.options.webUrl}...`);
46
47
  }
47
- let requestUrl = '';
48
+ let requestUrl = `${args.options.webUrl}/_api/web/`;
48
49
  if (args.options.listId) {
49
- requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/ContentTypes('${encodeURIComponent(args.options.contentTypeId)}')`;
50
+ requestUrl += `lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')`;
50
51
  }
51
- else {
52
- requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/ContentTypes('${encodeURIComponent(args.options.contentTypeId)}')`;
52
+ else if (args.options.listTitle) {
53
+ requestUrl += `lists/getByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')`;
54
+ }
55
+ else if (args.options.listUrl) {
56
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
57
+ requestUrl += `GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')`;
53
58
  }
54
59
  const requestOptions = {
55
- url: requestUrl,
60
+ url: `${requestUrl}/ContentTypes('${encodeURIComponent(args.options.contentTypeId)}')`,
56
61
  headers: {
57
62
  'X-HTTP-Method': 'DELETE',
58
63
  'If-Match': '*',
@@ -75,7 +80,7 @@ class SpoListContentTypeRemoveCommand extends SpoCommand_1.default {
75
80
  type: 'confirm',
76
81
  name: 'continue',
77
82
  default: false,
78
- message: `Are you sure you want to remove the content type ${args.options.contentTypeId} from the list ${args.options.listId || args.options.listTitle} in site ${args.options.webUrl}?`
83
+ message: `Are you sure you want to remove the content type ${args.options.contentTypeId} from the list ${args.options.listId ? args.options.listId : args.options.listTitle ? args.options.listTitle : args.options.listUrl} in site ${args.options.webUrl}?`
79
84
  });
80
85
  if (result.continue) {
81
86
  yield removeContentTypeFromList();
@@ -89,6 +94,7 @@ _SpoListContentTypeRemoveCommand_instances = new WeakSet(), _SpoListContentTypeR
89
94
  Object.assign(this.telemetryProperties, {
90
95
  listId: typeof args.options.listId !== 'undefined',
91
96
  listTitle: typeof args.options.listTitle !== 'undefined',
97
+ listUrl: typeof args.options.listUrl !== 'undefined',
92
98
  confirm: (!(!args.options.confirm)).toString()
93
99
  });
94
100
  });
@@ -99,6 +105,8 @@ _SpoListContentTypeRemoveCommand_instances = new WeakSet(), _SpoListContentTypeR
99
105
  option: '-l, --listId [listId]'
100
106
  }, {
101
107
  option: '-t, --listTitle [listTitle]'
108
+ }, {
109
+ option: '--listUrl [listUrl]'
102
110
  }, {
103
111
  option: '-c, --contentTypeId <contentTypeId>'
104
112
  }, {
@@ -120,7 +128,7 @@ _SpoListContentTypeRemoveCommand_instances = new WeakSet(), _SpoListContentTypeR
120
128
  }, _SpoListContentTypeRemoveCommand_initTypes = function _SpoListContentTypeRemoveCommand_initTypes() {
121
129
  this.types.string.push('contentTypeId', 'c');
122
130
  }, _SpoListContentTypeRemoveCommand_initOptionSets = function _SpoListContentTypeRemoveCommand_initOptionSets() {
123
- this.optionSets.push(['listId', 'listTitle']);
131
+ this.optionSets.push(['listId', 'listTitle', 'listUrl']);
124
132
  };
125
133
  module.exports = new SpoListContentTypeRemoveCommand();
126
134
  //# sourceMappingURL=list-contenttype-remove.js.map
@@ -17,6 +17,7 @@ var _SpoListWebhookAddCommand_instances, _SpoListWebhookAddCommand_initTelemetry
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const request_1 = require("../../../../request");
19
19
  const formatting_1 = require("../../../../utils/formatting");
20
+ const urlUtil_1 = require("../../../../utils/urlUtil");
20
21
  const validation_1 = require("../../../../utils/validation");
21
22
  const SpoCommand_1 = require("../../../base/SpoCommand");
22
23
  const commands_1 = require("../../commands");
@@ -42,17 +43,21 @@ class SpoListWebhookAddCommand extends SpoCommand_1.default {
42
43
  commandAction(logger, args) {
43
44
  return __awaiter(this, void 0, void 0, function* () {
44
45
  if (this.verbose) {
45
- logger.logToStderr(`Adding webhook to list ${args.options.listId ? args.options.listId : args.options.listTitle} located at site ${args.options.webUrl}...`);
46
+ logger.logToStderr(`Adding webhook to list ${args.options.listId || args.options.listTitle || args.options.listUrl} located at site ${args.options.webUrl}...`);
46
47
  }
47
- let requestUrl = '';
48
+ let requestUrl = `${args.options.webUrl}/_api/web`;
48
49
  if (args.options.listId) {
49
- requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions')`;
50
+ requestUrl += `/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions`;
50
51
  }
51
- else {
52
- requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions')`;
52
+ else if (args.options.listTitle) {
53
+ requestUrl += `/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions`;
54
+ }
55
+ else if (args.options.listUrl) {
56
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
57
+ requestUrl += `/GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/Subscriptions`;
53
58
  }
54
59
  const requestBody = {};
55
- requestBody.resource = args.options.listId ? args.options.listId : args.options.listTitle;
60
+ requestBody.resource = args.options.listId || args.options.listTitle || args.options.listUrl;
56
61
  requestBody.notificationUrl = args.options.notificationUrl;
57
62
  // If no expiration date has been provided we will default to the
58
63
  // maximum expiration date of 180 days from now
@@ -84,10 +89,11 @@ class SpoListWebhookAddCommand extends SpoCommand_1.default {
84
89
  _SpoListWebhookAddCommand_instances = new WeakSet(), _SpoListWebhookAddCommand_initTelemetry = function _SpoListWebhookAddCommand_initTelemetry() {
85
90
  this.telemetry.push((args) => {
86
91
  Object.assign(this.telemetryProperties, {
87
- listId: (!(!args.options.listId)).toString(),
88
- listTitle: (!(!args.options.listTitle)).toString(),
89
- expirationDateTime: (!(!args.options.expirationDateTime)).toString(),
90
- clientState: (!(!args.options.clientState)).toString()
92
+ listId: typeof args.options.listId !== 'undefined',
93
+ listTitle: typeof args.options.listTitle !== 'undefined',
94
+ listUrl: typeof args.options.listUrl !== 'undefined',
95
+ expirationDateTime: typeof args.options.expirationDateTime !== 'undefined',
96
+ clientState: typeof args.options.clientState !== 'undefined'
91
97
  });
92
98
  });
93
99
  }, _SpoListWebhookAddCommand_initOptions = function _SpoListWebhookAddCommand_initOptions() {
@@ -97,6 +103,8 @@ _SpoListWebhookAddCommand_instances = new WeakSet(), _SpoListWebhookAddCommand_i
97
103
  option: '-l, --listId [listId]'
98
104
  }, {
99
105
  option: '-t, --listTitle [listTitle]'
106
+ }, {
107
+ option: '--listUrl [listUrl]'
100
108
  }, {
101
109
  option: '-n, --notificationUrl <notificationUrl>'
102
110
  }, {
@@ -129,7 +137,7 @@ _SpoListWebhookAddCommand_instances = new WeakSet(), _SpoListWebhookAddCommand_i
129
137
  return true;
130
138
  }));
131
139
  }, _SpoListWebhookAddCommand_initOptionSets = function _SpoListWebhookAddCommand_initOptionSets() {
132
- this.optionSets.push(['listId', 'listTitle']);
140
+ this.optionSets.push(['listId', 'listTitle', 'listUrl']);
133
141
  };
134
142
  module.exports = new SpoListWebhookAddCommand();
135
143
  //# sourceMappingURL=list-webhook-add.js.map
@@ -17,6 +17,7 @@ var _SpoListWebhookGetCommand_instances, _SpoListWebhookGetCommand_initTelemetry
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const request_1 = require("../../../../request");
19
19
  const formatting_1 = require("../../../../utils/formatting");
20
+ const urlUtil_1 = require("../../../../utils/urlUtil");
20
21
  const validation_1 = require("../../../../utils/validation");
21
22
  const SpoCommand_1 = require("../../../base/SpoCommand");
22
23
  const commands_1 = require("../../commands");
@@ -38,15 +39,19 @@ class SpoListWebhookGetCommand extends SpoCommand_1.default {
38
39
  commandAction(logger, args) {
39
40
  return __awaiter(this, void 0, void 0, function* () {
40
41
  if (this.verbose) {
41
- const list = (args.options.listId ? args.options.listId : args.options.listTitle);
42
+ const list = (args.options.listId || args.options.listTitle || args.options.listUrl);
42
43
  logger.logToStderr(`Retrieving information for webhook ${args.options.id} belonging to list ${list} in site at ${args.options.webUrl}...`);
43
44
  }
44
- let requestUrl = '';
45
+ let requestUrl = `${args.options.webUrl}/_api/web`;
45
46
  if (args.options.listId) {
46
- requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
47
+ requestUrl += `/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
47
48
  }
48
- else {
49
- requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
49
+ else if (args.options.listTitle) {
50
+ requestUrl += `/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
51
+ }
52
+ else if (args.options.listUrl) {
53
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
54
+ requestUrl += `/GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
50
55
  }
51
56
  const requestOptions = {
52
57
  url: requestUrl,
@@ -72,9 +77,10 @@ class SpoListWebhookGetCommand extends SpoCommand_1.default {
72
77
  _SpoListWebhookGetCommand_instances = new WeakSet(), _SpoListWebhookGetCommand_initTelemetry = function _SpoListWebhookGetCommand_initTelemetry() {
73
78
  this.telemetry.push((args) => {
74
79
  Object.assign(this.telemetryProperties, {
75
- listId: (!(!args.options.listId)).toString(),
76
- listTitle: (!(!args.options.listTitle)).toString(),
77
- id: (!(!args.options.id)).toString()
80
+ listId: typeof args.options.listId !== 'undefined',
81
+ listTitle: typeof args.options.listTitle !== 'undefined',
82
+ listUrl: typeof args.options.listUrl !== 'undefined',
83
+ id: typeof args.options.id !== 'undefined'
78
84
  });
79
85
  });
80
86
  }, _SpoListWebhookGetCommand_initOptions = function _SpoListWebhookGetCommand_initOptions() {
@@ -84,6 +90,8 @@ _SpoListWebhookGetCommand_instances = new WeakSet(), _SpoListWebhookGetCommand_i
84
90
  option: '-l, --listId [listId]'
85
91
  }, {
86
92
  option: '-t, --listTitle [listTitle]'
93
+ }, {
94
+ option: '--listUrl [listUrl]'
87
95
  }, {
88
96
  option: '-i, --id [id]'
89
97
  });
@@ -104,7 +112,7 @@ _SpoListWebhookGetCommand_instances = new WeakSet(), _SpoListWebhookGetCommand_i
104
112
  return true;
105
113
  }));
106
114
  }, _SpoListWebhookGetCommand_initOptionSets = function _SpoListWebhookGetCommand_initOptionSets() {
107
- this.optionSets.push(['listId', 'listTitle']);
115
+ this.optionSets.push(['listId', 'listTitle', 'listUrl']);
108
116
  };
109
117
  module.exports = new SpoListWebhookGetCommand();
110
118
  //# sourceMappingURL=list-webhook-get.js.map
@@ -13,11 +13,12 @@ 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 _SpoListWebhookListCommand_instances, _SpoListWebhookListCommand_initTelemetry, _SpoListWebhookListCommand_initOptions, _SpoListWebhookListCommand_initValidators;
16
+ var _SpoListWebhookListCommand_instances, _SpoListWebhookListCommand_initTelemetry, _SpoListWebhookListCommand_initOptions, _SpoListWebhookListCommand_initValidators, _SpoListWebhookListCommand_initOptionSets;
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const chalk = require("chalk");
19
19
  const request_1 = require("../../../../request");
20
20
  const formatting_1 = require("../../../../utils/formatting");
21
+ const urlUtil_1 = require("../../../../utils/urlUtil");
21
22
  const validation_1 = require("../../../../utils/validation");
22
23
  const SpoCommand_1 = require("../../../base/SpoCommand");
23
24
  const commands_1 = require("../../commands");
@@ -28,6 +29,7 @@ class SpoListWebhookListCommand extends SpoCommand_1.default {
28
29
  __classPrivateFieldGet(this, _SpoListWebhookListCommand_instances, "m", _SpoListWebhookListCommand_initTelemetry).call(this);
29
30
  __classPrivateFieldGet(this, _SpoListWebhookListCommand_instances, "m", _SpoListWebhookListCommand_initOptions).call(this);
30
31
  __classPrivateFieldGet(this, _SpoListWebhookListCommand_instances, "m", _SpoListWebhookListCommand_initValidators).call(this);
32
+ __classPrivateFieldGet(this, _SpoListWebhookListCommand_instances, "m", _SpoListWebhookListCommand_initOptionSets).call(this);
31
33
  }
32
34
  get name() {
33
35
  return commands_1.default.LIST_WEBHOOK_LIST;
@@ -47,21 +49,24 @@ class SpoListWebhookListCommand extends SpoCommand_1.default {
47
49
  logger.logToStderr(chalk.yellow(`Option 'id' is deprecated. Please use 'listId' instead`));
48
50
  }
49
51
  if (this.verbose) {
50
- const list = args.options.id ? formatting_1.formatting.encodeQueryParameter(args.options.id) : (args.options.listId ? formatting_1.formatting.encodeQueryParameter(args.options.listId) : (args.options.title ? formatting_1.formatting.encodeQueryParameter(args.options.title) : formatting_1.formatting.encodeQueryParameter(args.options.listTitle)));
51
- logger.logToStderr(`Retrieving webhook information for list ${list} in site at ${args.options.webUrl}...`);
52
+ logger.logToStderr(`Retrieving webhook information for list ${args.options.id || args.options.listId || args.options.listUrl} in site at ${args.options.webUrl}...`);
52
53
  }
53
- let requestUrl = '';
54
+ let requestUrl = `${args.options.webUrl}/_api/web`;
54
55
  if (args.options.id) {
55
- requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.id)}')/Subscriptions`;
56
+ requestUrl += `/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.id)}')/Subscriptions`;
56
57
  }
57
58
  else if (args.options.listId) {
58
- requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions`;
59
+ requestUrl += `/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions`;
59
60
  }
60
61
  else if (args.options.listTitle) {
61
- requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions`;
62
+ requestUrl += `/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions`;
62
63
  }
63
- else {
64
- requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.title)}')/Subscriptions`;
64
+ else if (args.options.title) {
65
+ requestUrl += `/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.title)}')/Subscriptions`;
66
+ }
67
+ else if (args.options.listUrl) {
68
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
69
+ requestUrl += `/GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/Subscriptions`;
65
70
  }
66
71
  const requestOptions = {
67
72
  url: requestUrl,
@@ -94,10 +99,11 @@ class SpoListWebhookListCommand extends SpoCommand_1.default {
94
99
  _SpoListWebhookListCommand_instances = new WeakSet(), _SpoListWebhookListCommand_initTelemetry = function _SpoListWebhookListCommand_initTelemetry() {
95
100
  this.telemetry.push((args) => {
96
101
  Object.assign(this.telemetryProperties, {
97
- id: (!(!args.options.id)).toString(),
98
- listId: (!(!args.options.listId)).toString(),
99
- listTitle: (!(!args.options.listTitle)).toString(),
100
- title: (!(!args.options.title)).toString()
102
+ id: typeof args.options.id !== 'undefined',
103
+ listId: typeof args.options.listId !== 'undefined',
104
+ listTitle: typeof args.options.listTitle !== 'undefined',
105
+ listUrl: typeof args.options.listUrl !== 'undefined',
106
+ title: typeof args.options.title !== 'undefined'
101
107
  });
102
108
  });
103
109
  }, _SpoListWebhookListCommand_initOptions = function _SpoListWebhookListCommand_initOptions() {
@@ -107,6 +113,8 @@ _SpoListWebhookListCommand_instances = new WeakSet(), _SpoListWebhookListCommand
107
113
  option: '-i, --listId [listId]'
108
114
  }, {
109
115
  option: '-t, --listTitle [listTitle]'
116
+ }, {
117
+ option: '--listUrl [listUrl]'
110
118
  }, {
111
119
  option: '--id [id]'
112
120
  }, {
@@ -128,19 +136,10 @@ _SpoListWebhookListCommand_instances = new WeakSet(), _SpoListWebhookListCommand
128
136
  return `${args.options.listId} is not a valid GUID`;
129
137
  }
130
138
  }
131
- if (args.options.id && args.options.title) {
132
- return 'Specify id or title, but not both';
133
- }
134
- if (args.options.listId && args.options.listTitle) {
135
- return 'Specify listId or listTitle, but not both';
136
- }
137
- if (!args.options.id && !args.options.title) {
138
- if (!args.options.listId && !args.options.listTitle) {
139
- return 'Specify listId or listTitle, one is required';
140
- }
141
- }
142
139
  return true;
143
140
  }));
141
+ }, _SpoListWebhookListCommand_initOptionSets = function _SpoListWebhookListCommand_initOptionSets() {
142
+ this.optionSets.push(['id', 'title', 'listId', 'listTitle', 'listUrl']);
144
143
  };
145
144
  module.exports = new SpoListWebhookListCommand();
146
145
  //# sourceMappingURL=list-webhook-list.js.map
@@ -18,6 +18,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const Cli_1 = require("../../../../cli/Cli");
19
19
  const request_1 = require("../../../../request");
20
20
  const formatting_1 = require("../../../../utils/formatting");
21
+ const urlUtil_1 = require("../../../../utils/urlUtil");
21
22
  const validation_1 = require("../../../../utils/validation");
22
23
  const SpoCommand_1 = require("../../../base/SpoCommand");
23
24
  const commands_1 = require("../../commands");
@@ -40,15 +41,19 @@ class SpoListWebhookRemoveCommand extends SpoCommand_1.default {
40
41
  return __awaiter(this, void 0, void 0, function* () {
41
42
  const removeWebhook = () => __awaiter(this, void 0, void 0, function* () {
42
43
  if (this.verbose) {
43
- const list = (args.options.listId ? args.options.listId : args.options.listTitle);
44
+ const list = (args.options.listId || args.options.listId || args.options.listUrl);
44
45
  logger.logToStderr(`Webhook ${args.options.id} is about to be removed from list ${list} located at site ${args.options.webUrl}...`);
45
46
  }
46
- let requestUrl = '';
47
+ let requestUrl = `${args.options.webUrl}/_api/web`;
47
48
  if (args.options.listId) {
48
- requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
49
+ requestUrl += `/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
49
50
  }
50
- else {
51
- requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
51
+ else if (args.options.listTitle) {
52
+ requestUrl += `/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
53
+ }
54
+ else if (args.options.listUrl) {
55
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
56
+ requestUrl += `/GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
52
57
  }
53
58
  const requestOptions = {
54
59
  url: requestUrl,
@@ -74,7 +79,7 @@ class SpoListWebhookRemoveCommand extends SpoCommand_1.default {
74
79
  type: 'confirm',
75
80
  name: 'continue',
76
81
  default: false,
77
- message: `Are you sure you want to remove webhook ${args.options.id} from list ${args.options.listTitle || args.options.listId} located at site ${args.options.webUrl}?`
82
+ message: `Are you sure you want to remove webhook ${args.options.id} from list ${args.options.listTitle || args.options.listId || args.options.listUrl} located at site ${args.options.webUrl}?`
78
83
  });
79
84
  if (result.continue) {
80
85
  yield removeWebhook();
@@ -86,10 +91,11 @@ class SpoListWebhookRemoveCommand extends SpoCommand_1.default {
86
91
  _SpoListWebhookRemoveCommand_instances = new WeakSet(), _SpoListWebhookRemoveCommand_initTelemetry = function _SpoListWebhookRemoveCommand_initTelemetry() {
87
92
  this.telemetry.push((args) => {
88
93
  Object.assign(this.telemetryProperties, {
89
- listId: (!(!args.options.listId)).toString(),
90
- listTitle: (!(!args.options.listTitle)).toString(),
91
- id: (!(!args.options.id)).toString(),
92
- confirm: (!(!args.options.confirm)).toString()
94
+ listId: typeof args.options.listId !== 'undefined',
95
+ listTitle: typeof args.options.listTitle !== 'undefined',
96
+ listUrl: typeof args.options.listUrl !== 'undefined',
97
+ id: typeof args.options.id !== 'undefined',
98
+ confirm: !!args.options.confirm
93
99
  });
94
100
  });
95
101
  }, _SpoListWebhookRemoveCommand_initOptions = function _SpoListWebhookRemoveCommand_initOptions() {
@@ -99,6 +105,8 @@ _SpoListWebhookRemoveCommand_instances = new WeakSet(), _SpoListWebhookRemoveCom
99
105
  option: '-l, --listId [listId]'
100
106
  }, {
101
107
  option: '-t, --listTitle [listTitle]'
108
+ }, {
109
+ option: '--listUrl [listUrl]'
102
110
  }, {
103
111
  option: '-i, --id <id>'
104
112
  }, {
@@ -121,7 +129,7 @@ _SpoListWebhookRemoveCommand_instances = new WeakSet(), _SpoListWebhookRemoveCom
121
129
  return true;
122
130
  }));
123
131
  }, _SpoListWebhookRemoveCommand_initOptionSets = function _SpoListWebhookRemoveCommand_initOptionSets() {
124
- this.optionSets.push(['listId', 'listTitle']);
132
+ this.optionSets.push(['listId', 'listTitle', 'listUrl']);
125
133
  };
126
134
  module.exports = new SpoListWebhookRemoveCommand();
127
135
  //# sourceMappingURL=list-webhook-remove.js.map
@@ -18,6 +18,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const chalk = require("chalk");
19
19
  const request_1 = require("../../../../request");
20
20
  const formatting_1 = require("../../../../utils/formatting");
21
+ const urlUtil_1 = require("../../../../utils/urlUtil");
21
22
  const validation_1 = require("../../../../utils/validation");
22
23
  const SpoCommand_1 = require("../../../base/SpoCommand");
23
24
  const commands_1 = require("../../commands");
@@ -39,14 +40,18 @@ class SpoListWebhookSetCommand extends SpoCommand_1.default {
39
40
  commandAction(logger, args) {
40
41
  return __awaiter(this, void 0, void 0, function* () {
41
42
  if (this.verbose) {
42
- logger.logToStderr(`Updating webhook ${args.options.id} belonging to list ${args.options.listId ? args.options.listId : args.options.listTitle} located at site ${args.options.webUrl}...`);
43
+ logger.logToStderr(`Updating webhook ${args.options.id} belonging to list ${args.options.listId || args.options.listTitle || args.options.listUrl} located at site ${args.options.webUrl}...`);
43
44
  }
44
- let requestUrl = '';
45
+ let requestUrl = `${args.options.webUrl}/_api/web`;
45
46
  if (args.options.listId) {
46
- requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
47
+ requestUrl += `/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
47
48
  }
48
- else {
49
- requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
49
+ else if (args.options.listTitle) {
50
+ requestUrl += `/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
51
+ }
52
+ else if (args.options.listUrl) {
53
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
54
+ requestUrl += `/GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
50
55
  }
51
56
  const requestBody = {};
52
57
  if (args.options.notificationUrl) {
@@ -77,10 +82,11 @@ class SpoListWebhookSetCommand extends SpoCommand_1.default {
77
82
  _SpoListWebhookSetCommand_instances = new WeakSet(), _SpoListWebhookSetCommand_initTelemetry = function _SpoListWebhookSetCommand_initTelemetry() {
78
83
  this.telemetry.push((args) => {
79
84
  Object.assign(this.telemetryProperties, {
80
- listId: (!(!args.options.listId)).toString(),
81
- listTitle: (!(!args.options.listTitle)).toString(),
82
- notificationUrl: (!(!args.options.notificationUrl)).toString(),
83
- expirationDateTime: (!(!args.options.expirationDateTime)).toString()
85
+ listId: typeof args.options.listId !== 'undefined',
86
+ listTitle: typeof args.options.listTitle !== 'undefined',
87
+ listUrl: typeof args.options.listUrl !== 'undefined',
88
+ notificationUrl: typeof args.options.notificationUrl !== 'undefined',
89
+ expirationDateTime: typeof args.options.expirationDateTime !== 'undefined'
84
90
  });
85
91
  });
86
92
  }, _SpoListWebhookSetCommand_initOptions = function _SpoListWebhookSetCommand_initOptions() {
@@ -90,6 +96,8 @@ _SpoListWebhookSetCommand_instances = new WeakSet(), _SpoListWebhookSetCommand_i
90
96
  option: '-l, --listId [listId]'
91
97
  }, {
92
98
  option: '-t, --listTitle [listTitle]'
99
+ }, {
100
+ option: '--listUrl [listUrl]'
93
101
  }, {
94
102
  option: '-i, --id <id>'
95
103
  }, {
@@ -125,7 +133,7 @@ _SpoListWebhookSetCommand_instances = new WeakSet(), _SpoListWebhookSetCommand_i
125
133
  return true;
126
134
  }));
127
135
  }, _SpoListWebhookSetCommand_initOptionSets = function _SpoListWebhookSetCommand_initOptionSets() {
128
- this.optionSets.push(['listId', 'listTitle']);
136
+ this.optionSets.push(['listId', 'listTitle', 'listUrl']);
129
137
  };
130
138
  module.exports = new SpoListWebhookSetCommand();
131
139
  //# sourceMappingURL=list-webhook-set.js.map
@@ -69,6 +69,7 @@ exports.default = {
69
69
  FOLDER_MOVE: `${prefix} folder move`,
70
70
  FOLDER_REMOVE: `${prefix} folder remove`,
71
71
  FOLDER_RENAME: `${prefix} folder rename`,
72
+ FOLDER_ROLEASSIGNMENT_REMOVE: `${prefix} folder roleassignment remove`,
72
73
  FOLDER_ROLEINHERITANCE_BREAK: `${prefix} folder roleinheritance break`,
73
74
  FOLDER_ROLEINHERITANCE_RESET: `${prefix} folder roleinheritance reset`,
74
75
  GET: `${prefix} get`,
@@ -16,6 +16,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
16
16
  var _TodoTaskSetCommand_instances, _TodoTaskSetCommand_initTelemetry, _TodoTaskSetCommand_initOptions, _TodoTaskSetCommand_initValidators, _TodoTaskSetCommand_initOptionSets;
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const request_1 = require("../../../../request");
19
+ const validation_1 = require("../../../../utils/validation");
19
20
  const GraphCommand_1 = require("../../../base/GraphCommand");
20
21
  const commands_1 = require("../../commands");
21
22
  class TodoTaskSetCommand extends GraphCommand_1.default {
@@ -76,7 +77,14 @@ class TodoTaskSetCommand extends GraphCommand_1.default {
76
77
  return Promise.resolve(taskList.id);
77
78
  });
78
79
  }
80
+ getDateTimeTimeZone(dateTime) {
81
+ return {
82
+ dateTime: dateTime,
83
+ timeZone: 'Etc/GMT'
84
+ };
85
+ }
79
86
  mapRequestBody(options) {
87
+ var _a;
80
88
  const requestBody = {};
81
89
  if (options.status) {
82
90
  requestBody.status = options.status;
@@ -84,6 +92,21 @@ class TodoTaskSetCommand extends GraphCommand_1.default {
84
92
  if (options.title) {
85
93
  requestBody.title = options.title;
86
94
  }
95
+ if (options.importance) {
96
+ requestBody.importance = options.importance.toLowerCase();
97
+ }
98
+ if (options.bodyContentType || options.bodyContent) {
99
+ requestBody.body = {
100
+ content: options.bodyContent,
101
+ contentType: ((_a = options.bodyContentType) === null || _a === void 0 ? void 0 : _a.toLowerCase()) || 'text'
102
+ };
103
+ }
104
+ if (options.dueDateTime) {
105
+ requestBody.dueDateTime = this.getDateTimeTimeZone(options.dueDateTime);
106
+ }
107
+ if (options.reminderDateTime) {
108
+ requestBody.reminderDateTime = this.getDateTimeTimeZone(options.reminderDateTime);
109
+ }
87
110
  return requestBody;
88
111
  }
89
112
  }
@@ -93,7 +116,12 @@ _TodoTaskSetCommand_instances = new WeakSet(), _TodoTaskSetCommand_initTelemetry
93
116
  listId: typeof args.options.listId !== 'undefined',
94
117
  listName: typeof args.options.listName !== 'undefined',
95
118
  status: typeof args.options.status !== 'undefined',
96
- title: typeof args.options.title !== 'undefined'
119
+ title: typeof args.options.title !== 'undefined',
120
+ bodyContent: typeof args.options.bodyContent !== 'undefined',
121
+ bodyContentType: args.options.bodyContentType,
122
+ dueDateTime: typeof args.options.dueDateTime !== 'undefined',
123
+ importance: args.options.importance,
124
+ reminderDateTime: typeof args.options.reminderDateTime !== 'undefined'
97
125
  });
98
126
  });
99
127
  }, _TodoTaskSetCommand_initOptions = function _TodoTaskSetCommand_initOptions() {
@@ -108,6 +136,18 @@ _TodoTaskSetCommand_instances = new WeakSet(), _TodoTaskSetCommand_initTelemetry
108
136
  option: '--listName [listName]'
109
137
  }, {
110
138
  option: '--listId [listId]'
139
+ }, {
140
+ option: '--bodyContent [bodyContent]'
141
+ }, {
142
+ option: '--bodyContentType [bodyContentType]',
143
+ autocomplete: ['text', 'html']
144
+ }, {
145
+ option: '--dueDateTime [dueDateTime]'
146
+ }, {
147
+ option: '--importance [importance]',
148
+ autocomplete: ['low', 'normal', 'high']
149
+ }, {
150
+ option: '--reminderDateTime [reminderDateTime]'
111
151
  });
112
152
  }, _TodoTaskSetCommand_initValidators = function _TodoTaskSetCommand_initValidators() {
113
153
  this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
@@ -119,6 +159,18 @@ _TodoTaskSetCommand_instances = new WeakSet(), _TodoTaskSetCommand_initTelemetry
119
159
  args.options.status !== 'deferred') {
120
160
  return `${args.options.status} is not a valid value. Allowed values are notStarted|inProgress|completed|waitingOnOthers|deferred`;
121
161
  }
162
+ if (args.options.bodyContentType && ['text', 'html'].indexOf(args.options.bodyContentType.toLowerCase()) === -1) {
163
+ return `'${args.options.bodyContentType}' is not a valid value for the bodyContentType option. Allowed values are text|html`;
164
+ }
165
+ if (args.options.importance && ['low', 'normal', 'high'].indexOf(args.options.importance.toLowerCase()) === -1) {
166
+ return `'${args.options.importance}' is not a valid value for the importance option. Allowed values are low|normal|high`;
167
+ }
168
+ if (args.options.dueDateTime && !validation_1.validation.isValidISODateTime(args.options.dueDateTime)) {
169
+ return `'${args.options.dueDateTime}' is not a valid ISO date string`;
170
+ }
171
+ if (args.options.reminderDateTime && !validation_1.validation.isValidISODateTime(args.options.reminderDateTime)) {
172
+ return `'${args.options.reminderDateTime}' is not a valid ISO date string`;
173
+ }
122
174
  return true;
123
175
  }));
124
176
  }, _TodoTaskSetCommand_initOptionSets = function _TodoTaskSetCommand_initOptionSets() {
@@ -0,0 +1,38 @@
1
+ # pp environment get
2
+
3
+ Gets information about the specified Power Platform environment
4
+
5
+ ## Usage
6
+
7
+ ```sh
8
+ m365 pp environment get [options]
9
+ ```
10
+
11
+ ## Options
12
+
13
+ `-n, --name <name>`
14
+ : The name of the environment to get information about
15
+
16
+ `-a, --asAdmin`
17
+ : Run the command as admin and retrieve details of environments you do not have explicitly assigned permissions to
18
+
19
+ ## Remarks
20
+
21
+ !!! attention
22
+ This command is based on an API that is currently in preview and is subject to change once the API reached general availability.
23
+ Register CLI for Microsoft 365 or Azure AD application as a management application for the Power Platform using
24
+ m365 pp managementapp add [options]
25
+
26
+ ## Examples
27
+
28
+ Get information about the Power Platform environment by name
29
+
30
+ ```sh
31
+ m365 pp environment get --name Default-d87a7535-dd31-4437-bfe1-95340acd55c5
32
+ ```
33
+
34
+ Get information as admin about the Power Platform environment by name
35
+
36
+ ```sh
37
+ m365 pp environment get --name Default-d87a7535-dd31-4437-bfe1-95340acd55c5 --asAdmin
38
+ ```
@@ -26,10 +26,10 @@ Specify either `listTitle`, `listId` or `listUrl`.
26
26
  Specify either `listTitle`, `listId` or `listUrl`.
27
27
 
28
28
  `-n, --name [name]`
29
- The name of the event receiver to retrieve. Specify either `name` or `id` but not both.
29
+ : The name of the event receiver to retrieve. Specify either `name` or `id` but not both.
30
30
 
31
31
  `-i, --id [id]`
32
- The id of the event receiver to retrieve. Specify either `name` or `id` but not both.
32
+ : The id of the event receiver to retrieve. Specify either `name` or `id` but not both.
33
33
 
34
34
  `-s, --scope [scope]`
35
35
  : The scope of which to retrieve the Event Receivers.
@@ -23,10 +23,10 @@ m365 spo eventreceiver remove [options]
23
23
  : The url of the list, _if the event receiver should be retrieved from a list_. Specify either `listTitle`, `listId` or `listUrl`.
24
24
 
25
25
  `-n, --name [name]`
26
- The name. Specify either `name` or `id` but not both.
26
+ : The name. Specify either `name` or `id` but not both.
27
27
 
28
28
  `-i, --id [id]`
29
- The id. Specify either `name` or `id` but not both.
29
+ : The id. Specify either `name` or `id` but not both.
30
30
 
31
31
  `-s, --scope [scope]`
32
32
  : The scope. Can be either "site" or "web". Defaults to "web". Only applicable when not specifying any of the list properties.