@pnp/cli-microsoft365 5.4.0-beta.d01ee78 → 5.4.0-beta.fdd7cb1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.devcontainer/Dockerfile +1 -1
- package/.eslintrc.js +1 -0
- package/dist/m365/aad/commands/o365group/o365group-conversation-post-list.js +4 -19
- package/dist/m365/aad/commands/o365group/o365group-get.js +3 -9
- package/dist/m365/base/PlannerCommand.js +10 -0
- package/dist/m365/flow/commands/flow-export.js +3 -3
- package/dist/m365/planner/commands/bucket/bucket-add.js +4 -16
- package/dist/m365/planner/commands/bucket/bucket-get.js +4 -18
- package/dist/m365/planner/commands/bucket/bucket-list.js +4 -17
- package/dist/m365/planner/commands/bucket/bucket-remove.js +4 -18
- package/dist/m365/planner/commands/bucket/bucket-set.js +4 -18
- package/dist/m365/planner/commands/plan/plan-add.js +4 -16
- package/dist/m365/planner/commands/plan/plan-details-get.js +4 -19
- package/dist/m365/planner/commands/plan/plan-get.js +4 -17
- package/dist/m365/planner/commands/plan/plan-list.js +4 -17
- package/dist/m365/planner/commands/task/task-add.js +4 -16
- package/dist/m365/planner/commands/task/task-checklistitem-add.js +89 -0
- package/dist/m365/planner/commands/task/task-get.js +40 -29
- package/dist/m365/planner/commands/task/task-list.js +4 -16
- package/dist/m365/planner/commands/task/task-remove.js +201 -0
- package/dist/m365/planner/commands/task/task-set.js +4 -16
- package/dist/m365/planner/commands/tenant/tenant-settings-list.js +33 -0
- package/dist/m365/planner/commands.js +5 -2
- package/dist/m365/spo/commands/contenttype/contenttype-add.js +1 -1
- package/dist/m365/spo/commands/contenttype/contenttype-field-remove.js +1 -1
- package/dist/m365/spo/commands/contenttype/contenttype-get.js +1 -1
- package/dist/m365/spo/commands/eventreceiver/eventreceiver-get.js +3 -3
- package/dist/m365/spo/commands/eventreceiver/eventreceiver-list.js +102 -0
- package/dist/m365/spo/commands/field/field-add.js +1 -1
- package/dist/m365/spo/commands/field/field-get.js +5 -5
- package/dist/m365/spo/commands/field/field-list.js +3 -3
- package/dist/m365/spo/commands/field/field-remove.js +5 -5
- package/dist/m365/spo/commands/file/file-sharinginfo-get.js +1 -1
- package/dist/m365/spo/commands/list/list-contenttype-add.js +3 -3
- package/dist/m365/spo/commands/list/list-contenttype-default-set.js +2 -2
- package/dist/m365/spo/commands/list/list-contenttype-list.js +3 -3
- package/dist/m365/spo/commands/list/list-contenttype-remove.js +3 -3
- package/dist/m365/spo/commands/list/list-get.js +2 -2
- package/dist/m365/spo/commands/list/list-label-get.js +3 -3
- package/dist/m365/spo/commands/list/list-label-set.js +2 -2
- package/dist/m365/spo/commands/list/list-remove.js +2 -2
- package/dist/m365/spo/commands/list/list-roleinheritance-break.js +2 -2
- package/dist/m365/spo/commands/list/list-roleinheritance-reset.js +2 -2
- package/dist/m365/spo/commands/list/list-sitescript-get.js +3 -3
- package/dist/m365/spo/commands/list/list-view-add.js +3 -3
- package/dist/m365/spo/commands/list/list-view-field-add.js +2 -2
- package/dist/m365/spo/commands/list/list-view-field-remove.js +2 -2
- package/dist/m365/spo/commands/list/list-view-field-set.js +2 -2
- package/dist/m365/spo/commands/list/list-view-get.js +4 -4
- package/dist/m365/spo/commands/list/list-view-list.js +3 -3
- package/dist/m365/spo/commands/list/list-view-remove.js +3 -3
- package/dist/m365/spo/commands/list/list-view-set.js +3 -3
- package/dist/m365/spo/commands/list/list-webhook-add.js +3 -3
- package/dist/m365/spo/commands/list/list-webhook-get.js +3 -3
- package/dist/m365/spo/commands/list/list-webhook-list.js +5 -5
- package/dist/m365/spo/commands/list/list-webhook-remove.js +4 -4
- package/dist/m365/spo/commands/list/list-webhook-set.js +3 -3
- package/dist/m365/spo/commands/listitem/listitem-add.js +2 -2
- package/dist/m365/spo/commands/listitem/listitem-attachment-list.js +2 -2
- package/dist/m365/spo/commands/listitem/listitem-get.js +2 -2
- package/dist/m365/spo/commands/listitem/listitem-isrecord.js +2 -2
- package/dist/m365/spo/commands/listitem/listitem-list.js +31 -11
- package/dist/m365/spo/commands/listitem/listitem-record-declare.js +2 -2
- package/dist/m365/spo/commands/listitem/listitem-record-undeclare.js +2 -2
- package/dist/m365/spo/commands/listitem/listitem-remove.js +2 -2
- package/dist/m365/spo/commands/listitem/listitem-roleinheritance-break.js +2 -2
- package/dist/m365/spo/commands/listitem/listitem-roleinheritance-reset.js +2 -2
- package/dist/m365/spo/commands/listitem/listitem-set.js +2 -2
- package/dist/m365/spo/commands/roledefinition/roledefinition-remove.js +82 -0
- package/dist/m365/spo/commands/site/site-remove.js +23 -37
- package/dist/m365/spo/commands.js +2 -0
- package/dist/m365/teams/commands/app/app-list.js +6 -20
- package/dist/m365/teams/commands/channel/channel-get.js +6 -19
- package/dist/m365/teams/commands/channel/channel-list.js +6 -18
- package/dist/m365/teams/commands/channel/channel-member-add.js +7 -18
- package/dist/m365/teams/commands/channel/channel-member-list.js +6 -19
- package/dist/m365/teams/commands/channel/channel-member-remove.js +6 -19
- package/dist/m365/teams/commands/channel/channel-member-set.js +6 -19
- package/dist/m365/teams/commands/tab/tab-get.js +6 -19
- package/dist/m365/teams/commands/team/team-add.js +2 -7
- package/dist/m365/teams/commands/team/team-get.js +6 -19
- package/dist/utils/aadGroup.js +57 -0
- package/dist/utils/index.js +2 -0
- package/dist/utils/validation.js +12 -2
- package/docs/docs/cmd/file/file-list.md +4 -4
- package/docs/docs/cmd/planner/bucket/bucket-set.md +4 -4
- package/docs/docs/cmd/planner/plan/plan-details-get.md +2 -2
- package/docs/docs/cmd/planner/plan/plan-get.md +4 -4
- package/docs/docs/cmd/planner/task/task-checklistitem-add.md +36 -0
- package/docs/docs/cmd/planner/task/task-get.md +3 -0
- package/docs/docs/cmd/planner/task/task-remove.md +78 -0
- package/docs/docs/cmd/planner/task/task-set.md +2 -2
- package/docs/docs/cmd/planner/tenant/tenant-settings-list.md +28 -0
- package/docs/docs/cmd/spo/eventreceiver/eventreceiver-list.md +64 -0
- package/docs/docs/cmd/spo/file/file-checkout.md +1 -1
- package/docs/docs/cmd/spo/listitem/listitem-list.md +16 -10
- package/docs/docs/cmd/spo/roledefinition/roledefinition-remove.md +36 -0
- package/package.json +12 -7
- package/dist/m365/planner/commands/task/task-details-get.js +0 -45
- package/docs/docs/cmd/planner/task/task-details-get.md +0 -24
|
@@ -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
|
-
|
|
27
|
-
|
|
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 =
|
|
32
|
-
`${args.options.webUrl}/_api/web/lists(guid'${
|
|
33
|
-
: `${args.options.webUrl}/_api/web/lists/getByTitle('${
|
|
39
|
+
const listRestUrl = listIdArgument ?
|
|
40
|
+
`${args.options.webUrl}/_api/web/lists(guid'${utils_1.formatting.encodeQueryParameter(listIdArgument)}')`
|
|
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: '
|
|
111
|
+
option: '--id [id]'
|
|
112
|
+
},
|
|
113
|
+
{
|
|
114
|
+
option: '--title [title]'
|
|
104
115
|
},
|
|
105
116
|
{
|
|
106
|
-
option: '-
|
|
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
|
|
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.
|
|
171
|
-
|
|
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;
|
|
@@ -25,8 +25,8 @@ class SpoListItemRecordDeclareCommand extends SpoCommand_1.default {
|
|
|
25
25
|
let webIdentity = '';
|
|
26
26
|
let listId = '';
|
|
27
27
|
const listRestUrl = args.options.listId
|
|
28
|
-
? `${args.options.webUrl}/_api/web/lists(guid'${
|
|
29
|
-
: `${args.options.webUrl}/_api/web/lists/getByTitle('${
|
|
28
|
+
? `${args.options.webUrl}/_api/web/lists(guid'${utils_1.formatting.encodeQueryParameter(args.options.listId)}')`
|
|
29
|
+
: `${args.options.webUrl}/_api/web/lists/getByTitle('${utils_1.formatting.encodeQueryParameter(args.options.listTitle)}')`;
|
|
30
30
|
utils_1.spo
|
|
31
31
|
.getRequestDigest(args.options.webUrl)
|
|
32
32
|
.then((contextResponse) => {
|
|
@@ -22,8 +22,8 @@ class SpoListItemRecordUndeclareCommand extends SpoCommand_1.default {
|
|
|
22
22
|
const listIdArgument = args.options.listId || '';
|
|
23
23
|
const listTitleArgument = args.options.listTitle || '';
|
|
24
24
|
const listRestUrl = (args.options.listId ?
|
|
25
|
-
`${args.options.webUrl}/_api/web/lists(guid'${
|
|
26
|
-
: `${args.options.webUrl}/_api/web/lists/getByTitle('${
|
|
25
|
+
`${args.options.webUrl}/_api/web/lists(guid'${utils_1.formatting.encodeQueryParameter(listIdArgument)}')`
|
|
26
|
+
: `${args.options.webUrl}/_api/web/lists/getByTitle('${utils_1.formatting.encodeQueryParameter(listTitleArgument)}')`);
|
|
27
27
|
let formDigestValue = '';
|
|
28
28
|
let environmentListId = '';
|
|
29
29
|
(() => {
|
|
@@ -27,10 +27,10 @@ class SpoListItemRemoveCommand extends SpoCommand_1.default {
|
|
|
27
27
|
}
|
|
28
28
|
let requestUrl = '';
|
|
29
29
|
if (args.options.listId) {
|
|
30
|
-
requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${
|
|
30
|
+
requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${utils_1.formatting.encodeQueryParameter(args.options.listId)}')`;
|
|
31
31
|
}
|
|
32
32
|
else {
|
|
33
|
-
requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${
|
|
33
|
+
requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${utils_1.formatting.encodeQueryParameter(args.options.listTitle)}')`;
|
|
34
34
|
}
|
|
35
35
|
requestUrl += `/items(${args.options.id})`;
|
|
36
36
|
if (args.options.recycle) {
|
|
@@ -22,10 +22,10 @@ class SpoListItemRoleInheritanceBreakCommand extends SpoCommand_1.default {
|
|
|
22
22
|
}
|
|
23
23
|
let requestUrl = `${args.options.webUrl}/_api/web/lists`;
|
|
24
24
|
if (args.options.listId) {
|
|
25
|
-
requestUrl += `(guid'${
|
|
25
|
+
requestUrl += `(guid'${utils_1.formatting.encodeQueryParameter(args.options.listId)}')`;
|
|
26
26
|
}
|
|
27
27
|
else {
|
|
28
|
-
requestUrl += `/getbytitle('${
|
|
28
|
+
requestUrl += `/getbytitle('${utils_1.formatting.encodeQueryParameter(args.options.listTitle)}')`;
|
|
29
29
|
}
|
|
30
30
|
let keepExistingPermissions = true;
|
|
31
31
|
if (args.options.clearExistingPermissions) {
|
|
@@ -20,10 +20,10 @@ class SpoListItemRoleInheritanceResetCommand extends SpoCommand_1.default {
|
|
|
20
20
|
commandAction(logger, args, cb) {
|
|
21
21
|
let requestUrl = `${args.options.webUrl}/_api/web/lists`;
|
|
22
22
|
if (args.options.listId) {
|
|
23
|
-
requestUrl += `(guid'${
|
|
23
|
+
requestUrl += `(guid'${utils_1.formatting.encodeQueryParameter(args.options.listId)}')`;
|
|
24
24
|
}
|
|
25
25
|
else {
|
|
26
|
-
requestUrl += `/getbytitle('${
|
|
26
|
+
requestUrl += `/getbytitle('${utils_1.formatting.encodeQueryParameter(args.options.listTitle)}')`;
|
|
27
27
|
}
|
|
28
28
|
const requestOptions = {
|
|
29
29
|
url: `${requestUrl}/items(${args.options.listItemId})/resetroleinheritance`,
|
|
@@ -27,8 +27,8 @@ class SpoListItemSetCommand extends SpoCommand_1.default {
|
|
|
27
27
|
const listIdArgument = args.options.listId || '';
|
|
28
28
|
const listTitleArgument = args.options.listTitle || '';
|
|
29
29
|
const listRestUrl = (args.options.listId ?
|
|
30
|
-
`${args.options.webUrl}/_api/web/lists(guid'${
|
|
31
|
-
: `${args.options.webUrl}/_api/web/lists/getByTitle('${
|
|
30
|
+
`${args.options.webUrl}/_api/web/lists(guid'${utils_1.formatting.encodeQueryParameter(listIdArgument)}')`
|
|
31
|
+
: `${args.options.webUrl}/_api/web/lists/getByTitle('${utils_1.formatting.encodeQueryParameter(listTitleArgument)}')`);
|
|
32
32
|
let contentTypeName = '';
|
|
33
33
|
let formDigestValue = '';
|
|
34
34
|
let environmentListId = '';
|
|
@@ -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
|
|
48
|
-
.
|
|
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((
|
|
56
|
-
if (
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
if (
|
|
64
|
-
|
|
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
|
-
|
|
73
|
-
|
|
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
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
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
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
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
|
-
|
|
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
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
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
|
-
|
|
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
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
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
|
-
|
|
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
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
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
|
|
124
|
+
return group.id;
|
|
136
125
|
});
|
|
137
126
|
}
|
|
138
127
|
getChannelId(teamId, args) {
|
|
@@ -4,6 +4,7 @@ const utils_1 = require("../../../../utils");
|
|
|
4
4
|
const GraphCommand_1 = require("../../../base/GraphCommand");
|
|
5
5
|
const commands_1 = require("../../commands");
|
|
6
6
|
const request_1 = require("../../../../request");
|
|
7
|
+
const aadGroup_1 = require("../../../../utils/aadGroup");
|
|
7
8
|
class TeamsChannelMemberListCommand extends GraphCommand_1.default {
|
|
8
9
|
constructor() {
|
|
9
10
|
super(...arguments);
|
|
@@ -60,27 +61,13 @@ class TeamsChannelMemberListCommand extends GraphCommand_1.default {
|
|
|
60
61
|
if (args.options.teamId) {
|
|
61
62
|
return Promise.resolve(args.options.teamId);
|
|
62
63
|
}
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
},
|
|
68
|
-
responseType: 'json'
|
|
69
|
-
};
|
|
70
|
-
return request_1.default
|
|
71
|
-
.get(requestOptions)
|
|
72
|
-
.then(response => {
|
|
73
|
-
const groupItem = response.value[0];
|
|
74
|
-
if (!groupItem) {
|
|
64
|
+
return aadGroup_1.aadGroup
|
|
65
|
+
.getGroupByDisplayName(args.options.teamName)
|
|
66
|
+
.then(group => {
|
|
67
|
+
if (group.resourceProvisioningOptions.indexOf('Team') === -1) {
|
|
75
68
|
return Promise.reject(`The specified team does not exist in the Microsoft Teams`);
|
|
76
69
|
}
|
|
77
|
-
|
|
78
|
-
return Promise.reject(`The specified team does not exist in the Microsoft Teams`);
|
|
79
|
-
}
|
|
80
|
-
if (response.value.length > 1) {
|
|
81
|
-
return Promise.reject(`Multiple Microsoft Teams teams with name ${args.options.teamName} found: ${response.value.map(x => x.id)}`);
|
|
82
|
-
}
|
|
83
|
-
return Promise.resolve(groupItem.id);
|
|
70
|
+
return group.id;
|
|
84
71
|
});
|
|
85
72
|
}
|
|
86
73
|
getChannelId(args) {
|
|
@@ -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 TeamsChannelMemberRemoveCommand extends GraphCommand_1.default {
|
|
9
10
|
constructor() {
|
|
10
11
|
super(...arguments);
|
|
@@ -94,27 +95,13 @@ class TeamsChannelMemberRemoveCommand extends GraphCommand_1.default {
|
|
|
94
95
|
if (args.options.teamId) {
|
|
95
96
|
return Promise.resolve(args.options.teamId);
|
|
96
97
|
}
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
},
|
|
102
|
-
responseType: 'json'
|
|
103
|
-
};
|
|
104
|
-
return request_1.default
|
|
105
|
-
.get(requestOptions)
|
|
106
|
-
.then(response => {
|
|
107
|
-
const groupItem = response.value[0];
|
|
108
|
-
if (!groupItem) {
|
|
98
|
+
return aadGroup_1.aadGroup
|
|
99
|
+
.getGroupByDisplayName(args.options.teamName)
|
|
100
|
+
.then(group => {
|
|
101
|
+
if (group.resourceProvisioningOptions.indexOf('Team') === -1) {
|
|
109
102
|
return Promise.reject(`The specified team does not exist in the Microsoft Teams`);
|
|
110
103
|
}
|
|
111
|
-
|
|
112
|
-
return Promise.reject(`The specified team does not exist in the Microsoft Teams`);
|
|
113
|
-
}
|
|
114
|
-
if (response.value.length > 1) {
|
|
115
|
-
return Promise.reject(`Multiple Microsoft Teams teams with name ${args.options.teamName} found: ${response.value.map(x => x.id)}`);
|
|
116
|
-
}
|
|
117
|
-
return Promise.resolve(groupItem.id);
|
|
104
|
+
return group.id;
|
|
118
105
|
});
|
|
119
106
|
}
|
|
120
107
|
getChannelId(args) {
|