@pnp/cli-microsoft365 5.4.0-beta.3879fc9 → 5.4.0-beta.5d38887

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 (64) hide show
  1. package/.eslintrc.js +1 -0
  2. package/dist/m365/aad/commands/app/app-set.js +4 -1
  3. package/dist/m365/aad/commands/o365group/o365group-conversation-post-list.js +4 -19
  4. package/dist/m365/aad/commands/o365group/o365group-get.js +3 -9
  5. package/dist/m365/aad/commands/o365group/o365group-recyclebinitem-remove.js +129 -0
  6. package/dist/m365/aad/commands.js +1 -0
  7. package/dist/m365/base/PlannerCommand.js +10 -0
  8. package/dist/m365/flow/commands/flow-export.js +3 -3
  9. package/dist/m365/planner/commands/bucket/bucket-add.js +4 -16
  10. package/dist/m365/planner/commands/bucket/bucket-get.js +4 -18
  11. package/dist/m365/planner/commands/bucket/bucket-list.js +4 -17
  12. package/dist/m365/planner/commands/bucket/bucket-remove.js +4 -18
  13. package/dist/m365/planner/commands/bucket/bucket-set.js +4 -18
  14. package/dist/m365/planner/commands/plan/plan-add.js +4 -16
  15. package/dist/m365/planner/commands/plan/plan-details-get.js +4 -19
  16. package/dist/m365/planner/commands/plan/plan-get.js +4 -17
  17. package/dist/m365/planner/commands/plan/plan-list.js +4 -17
  18. package/dist/m365/planner/commands/task/task-add.js +4 -16
  19. package/dist/m365/planner/commands/task/task-checklistitem-add.js +89 -0
  20. package/dist/m365/planner/commands/task/{task-details-get.js → task-checklistitem-list.js} +21 -13
  21. package/dist/m365/planner/commands/task/task-checklistitem-remove.js +85 -0
  22. package/dist/m365/planner/commands/task/task-get.js +40 -29
  23. package/dist/m365/planner/commands/task/task-list.js +4 -16
  24. package/dist/m365/planner/commands/task/task-reference-remove.js +125 -0
  25. package/dist/m365/planner/commands/task/task-set.js +4 -16
  26. package/dist/m365/planner/commands/tenant/tenant-settings-list.js +33 -0
  27. package/dist/m365/planner/commands.js +6 -1
  28. package/dist/m365/spo/commands/eventreceiver/eventreceiver-list.js +102 -0
  29. package/dist/m365/spo/commands/hubsite/hubsite-list.js +1 -1
  30. package/dist/m365/spo/commands/list/ListPrincipalType.js +13 -0
  31. package/dist/m365/spo/commands/list/list-get.js +6 -0
  32. package/dist/m365/spo/commands/list/list-list.js +10 -1
  33. package/dist/m365/spo/commands/listitem/listitem-list.js +30 -10
  34. package/dist/m365/spo/commands/roledefinition/roledefinition-remove.js +82 -0
  35. package/dist/m365/spo/commands/site/site-remove.js +23 -37
  36. package/dist/m365/spo/commands.js +2 -0
  37. package/dist/m365/teams/commands/app/app-list.js +6 -20
  38. package/dist/m365/teams/commands/channel/channel-get.js +6 -19
  39. package/dist/m365/teams/commands/channel/channel-list.js +6 -18
  40. package/dist/m365/teams/commands/channel/channel-member-add.js +7 -18
  41. package/dist/m365/teams/commands/channel/channel-member-list.js +6 -19
  42. package/dist/m365/teams/commands/channel/channel-member-remove.js +6 -19
  43. package/dist/m365/teams/commands/channel/channel-member-set.js +6 -19
  44. package/dist/m365/teams/commands/tab/tab-get.js +6 -19
  45. package/dist/m365/teams/commands/team/team-add.js +2 -7
  46. package/dist/m365/teams/commands/team/team-get.js +6 -19
  47. package/dist/utils/aadGroup.js +57 -0
  48. package/dist/utils/index.js +2 -0
  49. package/docs/docs/cmd/aad/app/app-set.md +1 -1
  50. package/docs/docs/cmd/aad/o365group/o365group-recyclebinitem-remove.md +45 -0
  51. package/docs/docs/cmd/file/file-list.md +4 -4
  52. package/docs/docs/cmd/planner/task/task-checklistitem-add.md +36 -0
  53. package/docs/docs/cmd/planner/task/task-checklistitem-list.md +24 -0
  54. package/docs/docs/cmd/planner/task/task-checklistitem-remove.md +36 -0
  55. package/docs/docs/cmd/planner/task/task-get.md +3 -0
  56. package/docs/docs/cmd/planner/task/task-reference-remove.md +39 -0
  57. package/docs/docs/cmd/planner/tenant/tenant-settings-list.md +28 -0
  58. package/docs/docs/cmd/spo/eventreceiver/eventreceiver-list.md +64 -0
  59. package/docs/docs/cmd/spo/hubsite/hubsite-list.md +1 -4
  60. package/docs/docs/cmd/spo/list/list-list.md +3 -0
  61. package/docs/docs/cmd/spo/listitem/listitem-list.md +16 -10
  62. package/docs/docs/cmd/spo/roledefinition/roledefinition-remove.md +36 -0
  63. package/package.json +1 -1
  64. package/docs/docs/cmd/planner/task/task-details-get.md +0 -24
@@ -0,0 +1,102 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const request_1 = require("../../../../request");
4
+ const utils_1 = require("../../../../utils");
5
+ const SpoCommand_1 = require("../../../base/SpoCommand");
6
+ const commands_1 = require("../../commands");
7
+ class SpoEventreceiverListCommand extends SpoCommand_1.default {
8
+ get name() {
9
+ return commands_1.default.EVENTRECEIVER_LIST;
10
+ }
11
+ get description() {
12
+ return 'Retrieves event receivers for the specified web, site or list.';
13
+ }
14
+ defaultProperties() {
15
+ return ['ReceiverId', 'ReceiverName'];
16
+ }
17
+ getTelemetryProperties(args) {
18
+ const telemetryProps = super.getTelemetryProperties(args);
19
+ telemetryProps.listId = typeof args.options.listId !== 'undefined';
20
+ telemetryProps.listTitle = typeof args.options.listTitle !== 'undefined';
21
+ telemetryProps.listUrl = typeof args.options.listUrl !== 'undefined';
22
+ telemetryProps.scope = typeof args.options.scope !== 'undefined';
23
+ return telemetryProps;
24
+ }
25
+ commandAction(logger, args, cb) {
26
+ let requestUrl = `${args.options.webUrl}/_api/`;
27
+ let listUrl = '';
28
+ if (args.options.listId) {
29
+ listUrl = `lists(guid'${encodeURIComponent(args.options.listId)}')/`;
30
+ }
31
+ else if (args.options.listTitle) {
32
+ listUrl = `lists/getByTitle('${encodeURIComponent(args.options.listTitle)}')/`;
33
+ }
34
+ else if (args.options.listUrl) {
35
+ const listServerRelativeUrl = utils_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
36
+ listUrl = `GetList('${encodeURIComponent(listServerRelativeUrl)}')/`;
37
+ }
38
+ if (!args.options.scope || args.options.scope === 'web') {
39
+ requestUrl += `web/${listUrl}eventreceivers`;
40
+ }
41
+ else {
42
+ requestUrl += 'site/eventreceivers';
43
+ }
44
+ const requestOptions = {
45
+ url: requestUrl,
46
+ headers: {
47
+ 'accept': 'application/json;odata=nometadata'
48
+ },
49
+ responseType: 'json'
50
+ };
51
+ request_1.default
52
+ .get(requestOptions)
53
+ .then((res) => {
54
+ logger.log(res.value);
55
+ cb();
56
+ }, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
57
+ }
58
+ options() {
59
+ const options = [
60
+ {
61
+ option: '-u, --webUrl <webUrl>'
62
+ },
63
+ {
64
+ option: '--listTitle [listTitle]'
65
+ },
66
+ {
67
+ option: '--listId [listId]'
68
+ },
69
+ {
70
+ option: '--listUrl [listUrl]'
71
+ },
72
+ {
73
+ option: '-s, --scope [scope]',
74
+ autocomplete: ['web', 'site']
75
+ }
76
+ ];
77
+ const parentOptions = super.options();
78
+ return options.concat(parentOptions);
79
+ }
80
+ validate(args) {
81
+ const isValidSharePointUrl = utils_1.validation.isValidSharePointUrl(args.options.webUrl);
82
+ if (isValidSharePointUrl !== true) {
83
+ return isValidSharePointUrl;
84
+ }
85
+ const listOptions = [args.options.listId, args.options.listTitle, args.options.listUrl];
86
+ if (listOptions.some(item => item !== undefined) && listOptions.filter(item => item !== undefined).length > 1) {
87
+ return `Specify either list id or title or list url`;
88
+ }
89
+ if (args.options.listId && !utils_1.validation.isValidGuid(args.options.listId)) {
90
+ return `${args.options.listId} is not a valid GUID`;
91
+ }
92
+ if (args.options.scope && ['web', 'site'].indexOf(args.options.scope) === -1) {
93
+ return `${args.options.scope} is not a valid type value. Allowed values web|site.`;
94
+ }
95
+ if (args.options.scope && args.options.scope === 'site' && (args.options.listId || args.options.listUrl || args.options.listTitle)) {
96
+ return 'Scope cannot be set to site when retrieving list event receivers.';
97
+ }
98
+ return true;
99
+ }
100
+ }
101
+ module.exports = new SpoEventreceiverListCommand();
102
+ //# sourceMappingURL=eventreceiver-list.js.map
@@ -42,7 +42,7 @@ class SpoHubSiteListCommand extends SpoCommand_1.default {
42
42
  })
43
43
  .then((res) => {
44
44
  hubSites = res.value;
45
- if (args.options.includeAssociatedSites !== true || args.options.output !== 'json') {
45
+ if (args.options.includeAssociatedSites !== true || args.options.output && args.options.output !== 'json') {
46
46
  return Promise.resolve();
47
47
  }
48
48
  else {
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ListPrincipalType = void 0;
4
+ var ListPrincipalType;
5
+ (function (ListPrincipalType) {
6
+ ListPrincipalType[ListPrincipalType["None"] = 0] = "None";
7
+ ListPrincipalType[ListPrincipalType["User"] = 1] = "User";
8
+ ListPrincipalType[ListPrincipalType["DistributionList"] = 2] = "DistributionList";
9
+ ListPrincipalType[ListPrincipalType["SecurityGroup"] = 4] = "SecurityGroup";
10
+ ListPrincipalType[ListPrincipalType["SharePointGroup"] = 8] = "SharePointGroup";
11
+ ListPrincipalType[ListPrincipalType["All"] = 15] = "All";
12
+ })(ListPrincipalType = exports.ListPrincipalType || (exports.ListPrincipalType = {}));
13
+ //# sourceMappingURL=ListPrincipalType.js.map
@@ -4,6 +4,7 @@ const request_1 = require("../../../../request");
4
4
  const utils_1 = require("../../../../utils");
5
5
  const SpoCommand_1 = require("../../../base/SpoCommand");
6
6
  const commands_1 = require("../../commands");
7
+ const ListPrincipalType_1 = require("./ListPrincipalType");
7
8
  class SpoListGetCommand extends SpoCommand_1.default {
8
9
  get name() {
9
10
  return commands_1.default.LIST_GET;
@@ -42,6 +43,11 @@ class SpoListGetCommand extends SpoCommand_1.default {
42
43
  request_1.default
43
44
  .get(requestOptions)
44
45
  .then((listInstance) => {
46
+ if (args.options.withPermissions) {
47
+ listInstance.RoleAssignments.forEach(r => {
48
+ r.Member.PrincipalTypeString = ListPrincipalType_1.ListPrincipalType[r.Member.PrincipalType];
49
+ });
50
+ }
45
51
  logger.log(listInstance);
46
52
  cb();
47
53
  }, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
@@ -14,12 +14,18 @@ class SpoListListCommand extends SpoCommand_1.default {
14
14
  defaultProperties() {
15
15
  return ['Title', 'Url', 'Id'];
16
16
  }
17
+ getTelemetryProperties(args) {
18
+ const telemetryProps = super.getTelemetryProperties(args);
19
+ telemetryProps.executeWithLimitedPermissions = !!args.options.executeWithLimitedPermissions;
20
+ return telemetryProps;
21
+ }
17
22
  commandAction(logger, args, cb) {
18
23
  if (this.verbose) {
19
24
  logger.logToStderr(`Retrieving all lists in site at ${args.options.webUrl}...`);
20
25
  }
26
+ const suffix = args.options.executeWithLimitedPermissions ? '&$select=RootFolder/ServerRelativeUrl,*' : '';
21
27
  const requestOptions = {
22
- url: `${args.options.webUrl}/_api/web/lists?$expand=RootFolder`,
28
+ url: `${args.options.webUrl}/_api/web/lists?$expand=RootFolder${suffix}`,
23
29
  method: 'GET',
24
30
  headers: {
25
31
  'accept': 'application/json;odata=nometadata'
@@ -40,6 +46,9 @@ class SpoListListCommand extends SpoCommand_1.default {
40
46
  const options = [
41
47
  {
42
48
  option: '-u, --webUrl <webUrl>'
49
+ },
50
+ {
51
+ option: '--executeWithLimitedPermissions'
43
52
  }
44
53
  ];
45
54
  const parentOptions = super.options();
@@ -14,6 +14,8 @@ class SpoListItemListCommand extends SpoCommand_1.default {
14
14
  getTelemetryProperties(args) {
15
15
  const telemetryProps = super.getTelemetryProperties(args);
16
16
  telemetryProps.id = typeof args.options.id !== 'undefined';
17
+ telemetryProps.listId = typeof args.options.listId !== 'undefined';
18
+ telemetryProps.listTitle = typeof args.options.listTitle !== 'undefined';
17
19
  telemetryProps.title = typeof args.options.title !== 'undefined';
18
20
  telemetryProps.fields = typeof args.options.fields !== 'undefined';
19
21
  telemetryProps.filter = typeof args.options.filter !== 'undefined';
@@ -23,14 +25,20 @@ class SpoListItemListCommand extends SpoCommand_1.default {
23
25
  return telemetryProps;
24
26
  }
25
27
  commandAction(logger, args, cb) {
26
- const listIdArgument = args.options.id || '';
27
- const listTitleArgument = args.options.title || '';
28
+ if (args.options.id) {
29
+ this.warn(logger, `Option 'id' is deprecated. Please use 'listId' instead.`);
30
+ }
31
+ if (args.options.title) {
32
+ this.warn(logger, `Option 'title' is deprecated. Please use 'listTitle' instead.`);
33
+ }
34
+ const listIdArgument = args.options.listId || args.options.id || '';
35
+ const listTitleArgument = args.options.listTitle || args.options.title || '';
28
36
  let formDigestValue = '';
29
37
  const fieldsArray = args.options.fields ? args.options.fields.split(",")
30
38
  : (!args.options.output || args.options.output === "text") ? ["Title", "Id"] : [];
31
- const listRestUrl = (args.options.id ?
39
+ const listRestUrl = listIdArgument ?
32
40
  `${args.options.webUrl}/_api/web/lists(guid'${utils_1.formatting.encodeQueryParameter(listIdArgument)}')`
33
- : `${args.options.webUrl}/_api/web/lists/getByTitle('${utils_1.formatting.encodeQueryParameter(listTitleArgument)}')`);
41
+ : `${args.options.webUrl}/_api/web/lists/getByTitle('${utils_1.formatting.encodeQueryParameter(listTitleArgument)}')`;
34
42
  (() => {
35
43
  if (args.options.camlQuery) {
36
44
  if (this.debug) {
@@ -100,10 +108,16 @@ class SpoListItemListCommand extends SpoCommand_1.default {
100
108
  option: '-u, --webUrl <webUrl>'
101
109
  },
102
110
  {
103
- option: '-i, --id [listId]'
111
+ option: '--id [id]'
112
+ },
113
+ {
114
+ option: '--title [title]'
104
115
  },
105
116
  {
106
- option: '-t, --title [listTitle]'
117
+ option: '-i, --listId [listId]'
118
+ },
119
+ {
120
+ option: '-t, --listTitle [listTitle]'
107
121
  },
108
122
  {
109
123
  option: '-s, --pageSize [pageSize]'
@@ -143,12 +157,16 @@ class SpoListItemListCommand extends SpoCommand_1.default {
143
157
  if (isValidSharePointUrl !== true) {
144
158
  return isValidSharePointUrl;
145
159
  }
146
- if (!args.options.id && !args.options.title) {
147
- return `Specify list id or title`;
160
+ if (!args.options.id && !args.options.title && !args.options.listId && !args.options.listTitle) {
161
+ return `Specify listId or listTitle`;
148
162
  }
149
163
  if (args.options.id && args.options.title) {
150
164
  return `Specify list id or title but not both`;
151
165
  }
166
+ // Check if only one of the 4 options is specified
167
+ if ([args.options.id, args.options.title, args.options.listId, args.options.listTitle].filter(o => o).length > 1) {
168
+ return 'Specify listId or listTitle but not both';
169
+ }
152
170
  if (args.options.camlQuery && args.options.fields) {
153
171
  return `Specify camlQuery or fields but not both`;
154
172
  }
@@ -167,8 +185,10 @@ class SpoListItemListCommand extends SpoCommand_1.default {
167
185
  if (args.options.pageNumber && isNaN(Number(args.options.pageNumber))) {
168
186
  return `pageNumber must be numeric`;
169
187
  }
170
- if (args.options.id &&
171
- !utils_1.validation.isValidGuid(args.options.id)) {
188
+ if (args.options.listId && !utils_1.validation.isValidGuid(args.options.listId)) {
189
+ return `${args.options.listId} is not a valid GUID`;
190
+ }
191
+ if (args.options.id && !utils_1.validation.isValidGuid(args.options.id)) {
172
192
  return `${args.options.id} in option id is not a valid GUID`;
173
193
  }
174
194
  return true;
@@ -0,0 +1,82 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const cli_1 = require("../../../../cli");
4
+ const request_1 = require("../../../../request");
5
+ const utils_1 = require("../../../../utils");
6
+ const SpoCommand_1 = require("../../../base/SpoCommand");
7
+ const commands_1 = require("../../commands");
8
+ class SpoRoleDefinitionRemoveCommand extends SpoCommand_1.default {
9
+ get name() {
10
+ return commands_1.default.ROLEDEFINITION_REMOVE;
11
+ }
12
+ get description() {
13
+ return 'Removes the role definition from the specified site';
14
+ }
15
+ getTelemetryProperties(args) {
16
+ const telemetryProps = super.getTelemetryProperties(args);
17
+ telemetryProps.confirm = (!(!args.options.confirm)).toString();
18
+ return telemetryProps;
19
+ }
20
+ commandAction(logger, args, cb) {
21
+ const removeRoleDefinition = () => {
22
+ if (this.verbose) {
23
+ logger.logToStderr(`Removing role definition from site ${args.options.webUrl}...`);
24
+ }
25
+ const requestOptions = {
26
+ url: `${args.options.webUrl}/_api/web/roledefinitions(${args.options.id})`,
27
+ method: 'delete',
28
+ headers: {
29
+ 'X-HTTP-Method': 'DELETE',
30
+ 'If-Match': '*',
31
+ 'accept': 'application/json;odata=nometadata'
32
+ },
33
+ responseType: 'json'
34
+ };
35
+ request_1.default
36
+ .delete(requestOptions)
37
+ .then(() => cb(), (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
38
+ };
39
+ if (args.options.confirm) {
40
+ removeRoleDefinition();
41
+ }
42
+ else {
43
+ cli_1.Cli.prompt({
44
+ type: 'confirm',
45
+ name: 'continue',
46
+ default: false,
47
+ message: `Are you sure you want to remove the role definition with id ${args.options.id} from site ${args.options.webUrl}?`
48
+ }, (result) => {
49
+ if (!result.continue) {
50
+ cb();
51
+ }
52
+ else {
53
+ removeRoleDefinition();
54
+ }
55
+ });
56
+ }
57
+ }
58
+ options() {
59
+ const options = [
60
+ {
61
+ option: '-u, --webUrl <webUrl>'
62
+ },
63
+ {
64
+ option: '-i, --id <id>'
65
+ },
66
+ {
67
+ option: '--confirm'
68
+ }
69
+ ];
70
+ const parentOptions = super.options();
71
+ return options.concat(parentOptions);
72
+ }
73
+ validate(args) {
74
+ const id = parseInt(args.options.id);
75
+ if (isNaN(id)) {
76
+ return `${args.options.id} is not a valid role definition ID`;
77
+ }
78
+ return utils_1.validation.isValidSharePointUrl(args.options.webUrl);
79
+ }
80
+ }
81
+ module.exports = new SpoRoleDefinitionRemoveCommand();
82
+ //# sourceMappingURL=roledefinition-remove.js.map
@@ -5,6 +5,7 @@ const cli_1 = require("../../../../cli");
5
5
  const config_1 = require("../../../../config");
6
6
  const request_1 = require("../../../../request");
7
7
  const utils_1 = require("../../../../utils");
8
+ const aadGroup_1 = require("../../../../utils/aadGroup");
8
9
  const SpoCommand_1 = require("../../../base/SpoCommand");
9
10
  const commands_1 = require("../../commands");
10
11
  class SpoSiteRemoveCommand extends SpoCommand_1.default {
@@ -44,41 +45,36 @@ class SpoSiteRemoveCommand extends SpoCommand_1.default {
44
45
  if (this.debug) {
45
46
  logger.logToStderr(`Site attached to group ${groupId}. Initiating group delete operation via Graph API`);
46
47
  }
47
- return this
48
- .getSiteGroup(groupId)
48
+ return aadGroup_1.aadGroup
49
+ .getGroupById(groupId)
49
50
  .then((group) => {
50
51
  if (args.options.skipRecycleBin || args.options.wait) {
51
52
  logger.logToStderr(chalk.yellow(`Entered site is a groupified site. Hence, the parameters 'skipRecycleBin' and 'wait' will not be applicable.`));
52
53
  }
53
54
  return this.deleteGroup(group.id, logger);
54
55
  })
55
- .catch((err) => {
56
- if (err.response.status === 404) {
57
- if (this.verbose) {
58
- logger.logToStderr(`Site group doesn't exist. Searching in the Microsoft 365 deleted groups.`);
59
- }
60
- return this
61
- .isSiteGroupDeleted(groupId)
62
- .then((deletedGroups) => {
63
- if (deletedGroups.value.length === 0) {
64
- if (this.verbose) {
65
- logger.logToStderr("Site group doesn't exist anymore. Deleting the site.");
66
- }
67
- if (args.options.wait) {
68
- logger.logToStderr(chalk.yellow(`Entered site is a groupified site. Hence, the parameter 'wait' will not be applicable.`));
69
- }
70
- return Promise.resolve();
56
+ .catch(() => {
57
+ if (this.verbose) {
58
+ logger.logToStderr(`Site group doesn't exist. Searching in the Microsoft 365 deleted groups.`);
59
+ }
60
+ return this
61
+ .isSiteGroupDeleted(groupId)
62
+ .then((deletedGroups) => {
63
+ if (deletedGroups.value.length === 0) {
64
+ if (this.verbose) {
65
+ logger.logToStderr("Site group doesn't exist anymore. Deleting the site.");
71
66
  }
72
- else {
73
- return Promise.reject(`Site group still exists in the deleted groups. The site won't be removed.`);
67
+ if (args.options.wait) {
68
+ logger.logToStderr(chalk.yellow(`Entered site is a groupified site. Hence, the parameter 'wait' will not be applicable.`));
74
69
  }
75
- })
76
- .then(_ => this.deleteOrphanedSite(logger, args.options.url))
77
- .catch((err) => Promise.reject(err));
78
- }
79
- else {
80
- return Promise.reject(err);
81
- }
70
+ return Promise.resolve();
71
+ }
72
+ else {
73
+ return Promise.reject(`Site group still exists in the deleted groups. The site won't be removed.`);
74
+ }
75
+ })
76
+ .then(_ => this.deleteOrphanedSite(logger, args.options.url))
77
+ .catch((err) => Promise.reject(err));
82
78
  })
83
79
  .then(_ => this.deleteSite(args.options.url, args.options.wait, logger));
84
80
  }
@@ -105,16 +101,6 @@ class SpoSiteRemoveCommand extends SpoCommand_1.default {
105
101
  });
106
102
  }
107
103
  }
108
- getSiteGroup(groupId) {
109
- const requestOptions = {
110
- url: `https://graph.microsoft.com/v1.0/groups/${groupId}`,
111
- headers: {
112
- accept: 'application/json;odata.metadata=none'
113
- },
114
- responseType: 'json'
115
- };
116
- return request_1.default.get(requestOptions);
117
- }
118
104
  isSiteGroupDeleted(groupId) {
119
105
  const requestOptions = {
120
106
  url: `https://graph.microsoft.com/v1.0/directory/deletedItems/Microsoft.Graph.Group?$select=id&$filter=groupTypes/any(c:c+eq+'Unified') and startswith(id, '${groupId}')`,
@@ -36,6 +36,7 @@ exports.default = {
36
36
  CUSTOMACTION_LIST: `${prefix} customaction list`,
37
37
  CUSTOMACTION_REMOVE: `${prefix} customaction remove`,
38
38
  EVENTRECEIVER_GET: `${prefix} eventreceiver get`,
39
+ EVENTRECEIVER_LIST: `${prefix} eventreceiver list`,
39
40
  EXTERNALUSER_LIST: `${prefix} externaluser list`,
40
41
  FEATURE_DISABLE: `${prefix} feature disable`,
41
42
  FEATURE_ENABLE: `${prefix} feature enable`,
@@ -167,6 +168,7 @@ exports.default = {
167
168
  REPORT_SITEUSAGESITECOUNTS: `${prefix} report siteusagesitecounts`,
168
169
  REPORT_SITEUSAGESTORAGE: `${prefix} report siteusagestorage`,
169
170
  ROLEDEFINITION_LIST: `${prefix} roledefinition list`,
171
+ ROLEDEFINITION_REMOVE: `${prefix} roledefinition remove`,
170
172
  SEARCH: `${prefix} search`,
171
173
  SERVICEPRINCIPAL_GRANT_ADD: `${prefix} serviceprincipal grant add`,
172
174
  SERVICEPRINCIPAL_GRANT_LIST: `${prefix} serviceprincipal grant list`,
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- const request_1 = require("../../../../request");
4
3
  const utils_1 = require("../../../../utils");
4
+ const aadGroup_1 = require("../../../../utils/aadGroup");
5
5
  const GraphCommand_1 = require("../../../base/GraphCommand");
6
6
  const commands_1 = require("../../commands");
7
7
  class TeamsAppListCommand extends GraphCommand_1.default {
@@ -25,27 +25,13 @@ class TeamsAppListCommand extends GraphCommand_1.default {
25
25
  if (args.options.teamId) {
26
26
  return Promise.resolve(args.options.teamId);
27
27
  }
28
- const requestOptions = {
29
- url: `${this.resource}/v1.0/groups?$filter=displayName eq '${encodeURIComponent(args.options.teamName)}'`,
30
- headers: {
31
- accept: 'application/json;odata.metadata=none'
32
- },
33
- responseType: 'json'
34
- };
35
- return request_1.default
36
- .get(requestOptions)
37
- .then(response => {
38
- const groupItem = response.value[0];
39
- if (!groupItem) {
40
- return Promise.reject(`The specified team does not exist in the Microsoft Teams`);
41
- }
42
- if (groupItem.resourceProvisioningOptions.indexOf('Team') === -1) {
28
+ return aadGroup_1.aadGroup
29
+ .getGroupByDisplayName(args.options.teamName)
30
+ .then(group => {
31
+ if (group.resourceProvisioningOptions.indexOf('Team') === -1) {
43
32
  return Promise.reject(`The specified team does not exist in the Microsoft Teams`);
44
33
  }
45
- if (response.value.length > 1) {
46
- return Promise.reject(`Multiple Microsoft Teams teams with name ${args.options.teamName} found: ${response.value.map(x => x.id)}`);
47
- }
48
- return Promise.resolve(groupItem.id);
34
+ return group.id;
49
35
  });
50
36
  }
51
37
  getEndpointUrl(args) {
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const request_1 = require("../../../../request");
4
4
  const utils_1 = require("../../../../utils");
5
+ const aadGroup_1 = require("../../../../utils/aadGroup");
5
6
  const GraphCommand_1 = require("../../../base/GraphCommand");
6
7
  const commands_1 = require("../../commands");
7
8
  class TeamsChannelGetCommand extends GraphCommand_1.default {
@@ -28,27 +29,13 @@ class TeamsChannelGetCommand extends GraphCommand_1.default {
28
29
  if (args.options.teamId) {
29
30
  return Promise.resolve(args.options.teamId);
30
31
  }
31
- const requestOptions = {
32
- url: `${this.resource}/v1.0/groups?$filter=displayName eq '${encodeURIComponent(args.options.teamName)}'`,
33
- headers: {
34
- accept: 'application/json;odata.metadata=none'
35
- },
36
- responseType: 'json'
37
- };
38
- return request_1.default
39
- .get(requestOptions)
40
- .then(response => {
41
- const groupItem = response.value[0];
42
- if (!groupItem) {
32
+ return aadGroup_1.aadGroup
33
+ .getGroupByDisplayName(args.options.teamName)
34
+ .then(group => {
35
+ if (group.resourceProvisioningOptions.indexOf('Team') === -1) {
43
36
  return Promise.reject(`The specified team does not exist in the Microsoft Teams`);
44
37
  }
45
- if (groupItem.resourceProvisioningOptions.indexOf('Team') === -1) {
46
- return Promise.reject(`The specified team does not exist in the Microsoft Teams`);
47
- }
48
- if (response.value.length > 1) {
49
- return Promise.reject(`Multiple Microsoft Teams teams with name ${args.options.teamName} found: ${response.value.map(x => x.id)}`);
50
- }
51
- return Promise.resolve(groupItem.id);
38
+ return group.id;
52
39
  });
53
40
  }
54
41
  getChannelId(args) {
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- const request_1 = require("../../../../request");
4
3
  const utils_1 = require("../../../../utils");
4
+ const aadGroup_1 = require("../../../../utils/aadGroup");
5
5
  const GraphCommand_1 = require("../../../base/GraphCommand");
6
6
  const commands_1 = require("../../commands");
7
7
  class TeamsChannelListCommand extends GraphCommand_1.default {
@@ -24,25 +24,13 @@ class TeamsChannelListCommand extends GraphCommand_1.default {
24
24
  if (args.options.teamId) {
25
25
  return Promise.resolve(args.options.teamId);
26
26
  }
27
- const requestOptions = {
28
- url: `${this.resource}/v1.0/groups?$filter=displayName eq '${encodeURIComponent(args.options.teamName)}'`,
29
- headers: {
30
- accept: 'application/json;odata.metadata=none'
31
- },
32
- responseType: 'json'
33
- };
34
- return request_1.default
35
- .get(requestOptions)
36
- .then(response => {
37
- const filteredResponseByTeam = response.value.filter(t => t.resourceProvisioningOptions.includes('Team'));
38
- const groupItem = filteredResponseByTeam[0];
39
- if (!groupItem) {
27
+ return aadGroup_1.aadGroup
28
+ .getGroupByDisplayName(args.options.teamName)
29
+ .then(group => {
30
+ if (group.resourceProvisioningOptions.indexOf('Team') === -1) {
40
31
  return Promise.reject(`The specified team does not exist in the Microsoft Teams`);
41
32
  }
42
- if (filteredResponseByTeam.length > 1) {
43
- return Promise.reject(`Multiple Microsoft Teams teams with name ${args.options.teamName} found: ${filteredResponseByTeam.map(x => x.id)}`);
44
- }
45
- return Promise.resolve(groupItem.id);
33
+ return group.id;
46
34
  });
47
35
  }
48
36
  commandAction(logger, args, cb) {
@@ -5,6 +5,7 @@ const request_1 = require("../../../../request");
5
5
  const utils_1 = require("../../../../utils");
6
6
  const GraphCommand_1 = require("../../../base/GraphCommand");
7
7
  const commands_1 = require("../../commands");
8
+ const aadGroup_1 = require("../../../../utils/aadGroup");
8
9
  class TeamsChannelMemberAddCommand extends GraphCommand_1.default {
9
10
  get name() {
10
11
  return commands_1.default.CHANNEL_MEMBER_ADD;
@@ -114,25 +115,13 @@ class TeamsChannelMemberAddCommand extends GraphCommand_1.default {
114
115
  if (args.options.teamId) {
115
116
  return Promise.resolve(args.options.teamId);
116
117
  }
117
- const requestOptions = {
118
- url: `${this.resource}/v1.0/groups?$filter=displayName eq '${encodeURIComponent(args.options.teamName)}'`,
119
- headers: {
120
- accept: 'application/json;odata.metadata=none'
121
- },
122
- responseType: 'json'
123
- };
124
- return request_1.default
125
- .get(requestOptions)
126
- .then(response => {
127
- const filteredResponseByTeam = response.value.filter(t => t.resourceProvisioningOptions.includes('Team'));
128
- const groupItem = filteredResponseByTeam[0];
129
- if (!groupItem) {
130
- return Promise.reject(`The specified team '${args.options.teamName}' does not exist in Microsoft Teams`);
131
- }
132
- if (filteredResponseByTeam.length > 1) {
133
- return Promise.reject(`Multiple Microsoft Teams with name '${args.options.teamName}' found. Please disambiguate:${os.EOL}${response.value.map(x => `- ${x.id}`).join(os.EOL)}`);
118
+ return aadGroup_1.aadGroup
119
+ .getGroupByDisplayName(args.options.teamName)
120
+ .then(group => {
121
+ if (group.resourceProvisioningOptions.indexOf('Team') === -1) {
122
+ return Promise.reject(`The specified team does not exist in the Microsoft Teams`);
134
123
  }
135
- return Promise.resolve(groupItem.id);
124
+ return group.id;
136
125
  });
137
126
  }
138
127
  getChannelId(teamId, args) {