@pnp/cli-microsoft365 5.0.0-beta.60ed6bc → 5.0.0-beta.6d4dbfb
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/devcontainer.json +9 -1
- package/.eslintrc.js +2 -0
- package/README.md +1 -1
- package/dist/Utils.js +7 -0
- package/dist/appInsights.js +5 -2
- package/dist/cli/Cli.js +24 -4
- package/dist/m365/aad/commands/app/app-add.js +58 -5
- package/dist/m365/aad/commands/app/app-get.js +97 -0
- package/dist/m365/aad/commands/group/group-list.js +41 -0
- package/dist/m365/aad/commands/o365group/{GroupUser.js → GroupExtended.js} +1 -1
- package/dist/m365/aad/commands/o365group/o365group-add.js +56 -50
- package/dist/m365/aad/commands/o365group/o365group-user-set.js +3 -3
- package/dist/m365/aad/commands/oauth2grant/oauth2grant-list.js +4 -4
- package/dist/m365/aad/commands/oauth2grant/oauth2grant-remove.js +36 -12
- package/dist/m365/aad/commands/user/user-get.js +33 -6
- package/dist/m365/aad/commands/user/user-hibp.js +67 -0
- package/dist/m365/aad/commands/user/user-list.js +7 -4
- package/dist/m365/aad/commands/user/user-password-validate.js +42 -0
- package/dist/m365/aad/commands.js +4 -0
- package/dist/m365/app/commands/permission/permission-list.js +266 -0
- package/dist/m365/app/commands.js +7 -0
- package/dist/m365/base/AppCommand.js +76 -0
- package/dist/m365/{aad/commands/o365group/Group.js → base/M365RcJson.js} +1 -1
- package/dist/m365/cli/commands/cli-doctor.js +2 -0
- package/dist/m365/cli/commands/config/config-set.js +4 -1
- package/dist/m365/file/commands/file-list.js +181 -0
- package/dist/m365/file/commands.js +2 -1
- package/dist/m365/flow/commands/flow-get.js +2 -2
- package/dist/m365/pa/cds-project-mutator.js +1 -1
- package/dist/m365/pa/commands/app/app-list.js +28 -1
- package/dist/m365/planner/AppliedCategories.js +3 -0
- package/dist/m365/planner/commands/task/task-add.js +288 -0
- package/dist/m365/planner/commands/task/task-details-get.js +39 -0
- package/dist/m365/planner/commands/task/task-get.js +37 -0
- package/dist/m365/planner/commands/task/task-set.js +357 -0
- package/dist/m365/planner/commands.js +5 -1
- package/dist/m365/search/commands/externalconnection/externalconnection-add.js +99 -0
- package/dist/m365/search/commands.js +7 -0
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN006005_CFG_PS_metadata.js +63 -0
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN006006_CFG_PS_features.js +60 -0
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN014008_CODE_launch_hostedWorkbench_type.js +62 -0
- package/dist/m365/spfx/commands/project/project-upgrade/upgrade-1.13.1.js +53 -0
- package/dist/m365/spfx/commands/project/project-upgrade/upgrade-1.14.0-beta.5.js +59 -0
- package/dist/m365/spfx/commands/project/project-upgrade.js +17 -13
- package/dist/m365/spfx/commands/spfx-doctor.js +176 -62
- package/dist/m365/spo/commands/contenttype/contenttype-list.js +52 -0
- package/dist/m365/spo/commands/group/group-user-add.js +64 -13
- package/dist/m365/spo/commands/group/group-user-remove.js +100 -0
- package/dist/m365/spo/commands/list/list-get.js +6 -2
- package/dist/m365/spo/commands/page/Page.js +3 -1
- package/dist/m365/spo/commands/page/page-add.js +7 -10
- package/dist/m365/spo/commands/page/page-set.js +7 -10
- package/dist/m365/spo/commands/site/site-ensure.js +1 -1
- package/dist/m365/spo/commands/site/site-recyclebinitem-list.js +76 -0
- package/dist/m365/spo/commands/site/site-remove.js +98 -30
- package/dist/m365/spo/commands/web/web-installedlanguage-list.js +48 -0
- package/dist/m365/spo/commands.js +5 -1
- package/dist/m365/teams/commands/app/app-list.js +9 -6
- package/dist/m365/teams/commands/chat/chat-list.js +43 -0
- package/dist/m365/teams/commands/chat/chat-member-list.js +42 -0
- package/dist/m365/teams/commands/chat/chat-message-list.js +60 -0
- package/dist/m365/teams/commands/message/message-get.js +1 -1
- package/dist/m365/teams/commands/report/report-directroutingcalls.js +1 -1
- package/dist/m365/teams/commands/tab/tab-get.js +9 -6
- package/dist/m365/teams/commands.js +3 -0
- package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-health-get.js +57 -0
- package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-health-list.js +56 -0
- package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-healthissue-get.js +39 -0
- package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-healthissue-list.js +38 -0
- package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-message-get.js +51 -0
- package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-message-list.js +38 -0
- package/dist/m365/tenant/commands.js +6 -0
- package/dist/request.js +9 -4
- package/dist/settingsNames.js +6 -1
- package/docs/docs/cmd/_global.md +2 -2
- package/docs/docs/cmd/aad/app/app-add.md +11 -0
- package/docs/docs/cmd/aad/app/app-get.md +48 -0
- package/docs/docs/cmd/aad/group/group-list.md +21 -0
- package/docs/docs/cmd/aad/o365group/o365group-add.md +1 -0
- package/docs/docs/cmd/aad/oauth2grant/oauth2grant-list.md +2 -2
- package/docs/docs/cmd/aad/oauth2grant/oauth2grant-remove.md +9 -0
- package/docs/docs/cmd/aad/user/user-get.md +13 -4
- package/docs/docs/cmd/aad/user/user-hibp.md +46 -0
- package/docs/docs/cmd/aad/user/user-list.md +9 -0
- package/docs/docs/cmd/aad/user/user-password-validate.md +29 -0
- package/docs/docs/cmd/app/permission/permission-list.md +36 -0
- package/docs/docs/cmd/file/file-list.md +46 -0
- package/docs/docs/cmd/pa/app/app-list.md +17 -1
- package/docs/docs/cmd/planner/task/task-add.md +78 -0
- package/docs/docs/cmd/planner/task/task-details-get.md +24 -0
- package/docs/docs/cmd/planner/task/task-get.md +24 -0
- package/docs/docs/cmd/planner/task/task-set.md +99 -0
- package/docs/docs/cmd/search/externalconnection/externalconnection-add.md +43 -0
- package/docs/docs/cmd/spfx/project/project-externalize.md +1 -1
- package/docs/docs/cmd/spfx/project/project-rename.md +1 -1
- package/docs/docs/cmd/spfx/project/project-upgrade.md +1 -1
- package/docs/docs/cmd/spfx/spfx-doctor.md +1 -1
- package/docs/docs/cmd/spo/contenttype/contenttype-list.md +33 -0
- package/docs/docs/cmd/spo/group/group-user-add.md +24 -6
- package/docs/docs/cmd/spo/group/group-user-remove.md +39 -0
- package/docs/docs/cmd/spo/list/list-get.md +9 -0
- package/docs/docs/cmd/spo/page/page-add.md +2 -2
- package/docs/docs/cmd/spo/page/page-set.md +3 -3
- package/docs/docs/cmd/spo/site/site-recyclebinitem-list.md +40 -0
- package/docs/docs/cmd/spo/site/site-remove.md +3 -1
- package/docs/docs/cmd/spo/web/web-installedlanguage-list.md +24 -0
- package/docs/docs/cmd/teams/channel/channel-get.md +1 -1
- package/docs/docs/cmd/teams/chat/chat-list.md +30 -0
- package/docs/docs/cmd/teams/chat/chat-member-list.md +24 -0
- package/docs/docs/cmd/teams/chat/chat-message-list.md +24 -0
- package/docs/docs/cmd/teams/message/message-get.md +0 -3
- package/docs/docs/cmd/teams/report/report-directroutingcalls.md +0 -3
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-health-get.md +33 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-health-list.md +30 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-healthissue-get.md +24 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-healthissue-list.md +34 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-message-get.md +28 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-message-list.md +34 -0
- package/npm-shrinkwrap.json +1308 -1478
- package/package.json +34 -27
- package/dist/m365/base/AadCommand.js +0 -10
|
@@ -3,8 +3,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
const cli_1 = require("../../../../cli");
|
|
4
4
|
const Command_1 = require("../../../../Command");
|
|
5
5
|
const request_1 = require("../../../../request");
|
|
6
|
-
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
7
6
|
const AadUserGetCommand = require("../../../aad/commands/user/user-get");
|
|
7
|
+
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
8
8
|
const commands_1 = require("../../commands");
|
|
9
9
|
class SpoGroupUserAddCommand extends SpoCommand_1.default {
|
|
10
10
|
get name() {
|
|
@@ -17,15 +17,21 @@ class SpoGroupUserAddCommand extends SpoCommand_1.default {
|
|
|
17
17
|
return ['DisplayName', 'Email'];
|
|
18
18
|
}
|
|
19
19
|
commandAction(logger, args, cb) {
|
|
20
|
-
|
|
20
|
+
let groupId = 0;
|
|
21
|
+
this
|
|
22
|
+
.getGroupId(args)
|
|
23
|
+
.then((_groupId) => {
|
|
24
|
+
groupId = _groupId;
|
|
25
|
+
return this.getOnlyActiveUsers(args, logger);
|
|
26
|
+
})
|
|
21
27
|
.then((resolvedUsernameList) => {
|
|
22
28
|
if (this.verbose) {
|
|
23
|
-
logger.logToStderr(`Start adding Active user/s to SharePoint Group ${args.options.groupId}
|
|
29
|
+
logger.logToStderr(`Start adding Active user/s to SharePoint Group ${args.options.groupId ? args.options.groupId : args.options.groupName}`);
|
|
24
30
|
}
|
|
25
31
|
const data = {
|
|
26
32
|
url: args.options.webUrl,
|
|
27
33
|
peoplePickerInput: this.getFormattedUserList(resolvedUsernameList),
|
|
28
|
-
roleValue: `group:${
|
|
34
|
+
roleValue: `group:${groupId}`
|
|
29
35
|
};
|
|
30
36
|
const requestOptions = {
|
|
31
37
|
url: `${args.options.webUrl}/_api/SP.Web.ShareObject`,
|
|
@@ -46,24 +52,51 @@ class SpoGroupUserAddCommand extends SpoCommand_1.default {
|
|
|
46
52
|
cb();
|
|
47
53
|
}, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
|
|
48
54
|
}
|
|
55
|
+
getGroupId(args) {
|
|
56
|
+
const getGroupMethod = args.options.groupName ?
|
|
57
|
+
`GetByName('${encodeURIComponent(args.options.groupName)}')` :
|
|
58
|
+
`GetById('${args.options.groupId}')`;
|
|
59
|
+
const requestOptions = {
|
|
60
|
+
url: `${args.options.webUrl}/_api/web/sitegroups/${getGroupMethod}`,
|
|
61
|
+
headers: {
|
|
62
|
+
'accept': 'application/json;odata=nometadata'
|
|
63
|
+
},
|
|
64
|
+
responseType: 'json'
|
|
65
|
+
};
|
|
66
|
+
return request_1.default
|
|
67
|
+
.get(requestOptions)
|
|
68
|
+
.then(response => {
|
|
69
|
+
const groupId = response.Id;
|
|
70
|
+
if (!groupId) {
|
|
71
|
+
return Promise.reject(`The specified group does not exist in the SharePoint site`);
|
|
72
|
+
}
|
|
73
|
+
return groupId;
|
|
74
|
+
});
|
|
75
|
+
}
|
|
49
76
|
getOnlyActiveUsers(args, logger) {
|
|
50
77
|
if (this.verbose) {
|
|
51
78
|
logger.logToStderr(`Removing Users which are not active from the original list`);
|
|
52
79
|
}
|
|
53
|
-
const
|
|
54
|
-
|
|
80
|
+
const activeUserNameList = [];
|
|
81
|
+
const userInfo = args.options.userName ? args.options.userName : args.options.email;
|
|
82
|
+
return Promise.all(userInfo.split(',').map(singleUserName => {
|
|
55
83
|
const options = {
|
|
56
|
-
userName: singleUsername.trim(),
|
|
57
84
|
output: 'json',
|
|
58
85
|
debug: args.options.debug,
|
|
59
86
|
verbose: args.options.verbose
|
|
60
87
|
};
|
|
88
|
+
if (args.options.userName) {
|
|
89
|
+
options.userName = singleUserName.trim();
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
options.email = singleUserName.trim();
|
|
93
|
+
}
|
|
61
94
|
return cli_1.Cli.executeCommandWithOutput(AadUserGetCommand, { options: Object.assign(Object.assign({}, options), { _: [] }) })
|
|
62
95
|
.then((getUserGetOutput) => {
|
|
63
96
|
if (this.debug) {
|
|
64
97
|
logger.logToStderr(getUserGetOutput.stderr);
|
|
65
98
|
}
|
|
66
|
-
|
|
99
|
+
activeUserNameList.push(JSON.parse(getUserGetOutput.stdout).userPrincipalName);
|
|
67
100
|
}, (err) => {
|
|
68
101
|
if (this.debug) {
|
|
69
102
|
logger.logToStderr(err.stderr);
|
|
@@ -71,7 +104,7 @@ class SpoGroupUserAddCommand extends SpoCommand_1.default {
|
|
|
71
104
|
});
|
|
72
105
|
}))
|
|
73
106
|
.then(() => {
|
|
74
|
-
return Promise.resolve(
|
|
107
|
+
return Promise.resolve(activeUserNameList);
|
|
75
108
|
});
|
|
76
109
|
}
|
|
77
110
|
getFormattedUserList(activeUserList) {
|
|
@@ -86,10 +119,16 @@ class SpoGroupUserAddCommand extends SpoCommand_1.default {
|
|
|
86
119
|
option: '-u, --webUrl <webUrl>'
|
|
87
120
|
},
|
|
88
121
|
{
|
|
89
|
-
option: '--groupId
|
|
122
|
+
option: '--groupId [groupId]'
|
|
90
123
|
},
|
|
91
124
|
{
|
|
92
|
-
option: '--
|
|
125
|
+
option: '--groupName [groupName]'
|
|
126
|
+
},
|
|
127
|
+
{
|
|
128
|
+
option: '--userName [userName]'
|
|
129
|
+
},
|
|
130
|
+
{
|
|
131
|
+
option: '--email [email]'
|
|
93
132
|
}
|
|
94
133
|
];
|
|
95
134
|
const parentOptions = super.options();
|
|
@@ -100,8 +139,20 @@ class SpoGroupUserAddCommand extends SpoCommand_1.default {
|
|
|
100
139
|
if (isValidSharePointUrl !== true) {
|
|
101
140
|
return isValidSharePointUrl;
|
|
102
141
|
}
|
|
103
|
-
if (
|
|
104
|
-
return
|
|
142
|
+
if (!args.options.groupId && !args.options.groupName) {
|
|
143
|
+
return 'Specify either groupId or groupName';
|
|
144
|
+
}
|
|
145
|
+
if (args.options.groupId && args.options.groupName) {
|
|
146
|
+
return 'Specify either groupId or groupName but not both';
|
|
147
|
+
}
|
|
148
|
+
if (!args.options.userName && !args.options.email) {
|
|
149
|
+
return 'Specify either userName or email';
|
|
150
|
+
}
|
|
151
|
+
if (args.options.userName && args.options.email) {
|
|
152
|
+
return 'Specify either userName or email but not both';
|
|
153
|
+
}
|
|
154
|
+
if (args.options.groupId && isNaN(args.options.groupId)) {
|
|
155
|
+
return `Specified groupId ${args.options.groupId} is not a number`;
|
|
105
156
|
}
|
|
106
157
|
return true;
|
|
107
158
|
}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const cli_1 = require("../../../../cli");
|
|
4
|
+
const request_1 = require("../../../../request");
|
|
5
|
+
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
6
|
+
const commands_1 = require("../../commands");
|
|
7
|
+
class SpoGroupUserRemoveCommand extends SpoCommand_1.default {
|
|
8
|
+
get name() {
|
|
9
|
+
return commands_1.default.GROUP_USER_REMOVE;
|
|
10
|
+
}
|
|
11
|
+
get description() {
|
|
12
|
+
return 'Removes the specified user from a SharePoint group';
|
|
13
|
+
}
|
|
14
|
+
getTelemetryProperties(args) {
|
|
15
|
+
const telemetryProps = super.getTelemetryProperties(args);
|
|
16
|
+
telemetryProps.groupId = (!(!args.options.groupId)).toString();
|
|
17
|
+
telemetryProps.groupName = (!(!args.options.groupName)).toString();
|
|
18
|
+
telemetryProps.confirm = (!(!args.options.confirm)).toString();
|
|
19
|
+
return telemetryProps;
|
|
20
|
+
}
|
|
21
|
+
commandAction(logger, args, cb) {
|
|
22
|
+
const removeUserfromSPGroup = () => {
|
|
23
|
+
if (this.verbose) {
|
|
24
|
+
logger.logToStderr(`Removing User with Username ${args.options.userName} from Group: ${args.options.groupId ? args.options.groupId : args.options.groupName}`);
|
|
25
|
+
}
|
|
26
|
+
const loginName = `i:0#.f|membership|${args.options.userName}`;
|
|
27
|
+
const requestUrl = `${args.options.webUrl}/_api/web/sitegroups/${args.options.groupId
|
|
28
|
+
? `GetById('${encodeURIComponent(args.options.groupId)}')`
|
|
29
|
+
: `GetByName('${encodeURIComponent(args.options.groupName)}')`}/users/removeByLoginName(@LoginName)?@LoginName='${encodeURIComponent(loginName)}'`;
|
|
30
|
+
const requestOptions = {
|
|
31
|
+
url: requestUrl,
|
|
32
|
+
headers: {
|
|
33
|
+
'accept': 'application/json;odata=nometadata'
|
|
34
|
+
},
|
|
35
|
+
responseType: 'json'
|
|
36
|
+
};
|
|
37
|
+
request_1.default
|
|
38
|
+
.post(requestOptions)
|
|
39
|
+
.then(() => {
|
|
40
|
+
cb();
|
|
41
|
+
}, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
|
|
42
|
+
};
|
|
43
|
+
if (args.options.confirm) {
|
|
44
|
+
if (this.debug) {
|
|
45
|
+
logger.logToStderr('Confirmation bypassed by entering confirm option. Removing the user from SharePoint Group...');
|
|
46
|
+
}
|
|
47
|
+
removeUserfromSPGroup();
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
cli_1.Cli.prompt({
|
|
51
|
+
type: 'confirm',
|
|
52
|
+
name: 'continue',
|
|
53
|
+
default: false,
|
|
54
|
+
message: `Are you sure you want to remove user User ${args.options.userName} from SharePoint group?`
|
|
55
|
+
}, (result) => {
|
|
56
|
+
if (!result.continue) {
|
|
57
|
+
cb();
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
removeUserfromSPGroup();
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
options() {
|
|
66
|
+
const options = [
|
|
67
|
+
{
|
|
68
|
+
option: '-u, --webUrl <webUrl>'
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
option: '--groupId [groupId]'
|
|
72
|
+
},
|
|
73
|
+
{
|
|
74
|
+
option: '--groupName [groupName]'
|
|
75
|
+
},
|
|
76
|
+
{
|
|
77
|
+
option: '--userName <userName>'
|
|
78
|
+
},
|
|
79
|
+
{
|
|
80
|
+
option: '--confirm'
|
|
81
|
+
}
|
|
82
|
+
];
|
|
83
|
+
const parentOptions = super.options();
|
|
84
|
+
return options.concat(parentOptions);
|
|
85
|
+
}
|
|
86
|
+
validate(args) {
|
|
87
|
+
if (args.options.groupId && args.options.groupName) {
|
|
88
|
+
return 'Use either "groupName" or "groupId", but not both';
|
|
89
|
+
}
|
|
90
|
+
if (!args.options.groupId && !args.options.groupName) {
|
|
91
|
+
return 'Either "groupName" or "groupId" is required';
|
|
92
|
+
}
|
|
93
|
+
if (args.options.groupId && isNaN(args.options.groupId)) {
|
|
94
|
+
return `Specified "groupId" ${args.options.groupId} is not valid`;
|
|
95
|
+
}
|
|
96
|
+
return SpoCommand_1.default.isValidSharePointUrl(args.options.webUrl);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
module.exports = new SpoGroupUserRemoveCommand();
|
|
100
|
+
//# sourceMappingURL=group-user-remove.js.map
|
|
@@ -16,6 +16,7 @@ class SpoListGetCommand extends SpoCommand_1.default {
|
|
|
16
16
|
telemetryProps.id = (!(!args.options.id)).toString();
|
|
17
17
|
telemetryProps.title = (!(!args.options.title)).toString();
|
|
18
18
|
telemetryProps.properties = (!(!args.options.properties)).toString();
|
|
19
|
+
telemetryProps.withPermissions = typeof args.options.withPermissions !== 'undefined';
|
|
19
20
|
return telemetryProps;
|
|
20
21
|
}
|
|
21
22
|
commandAction(logger, args, cb) {
|
|
@@ -29,10 +30,10 @@ class SpoListGetCommand extends SpoCommand_1.default {
|
|
|
29
30
|
else {
|
|
30
31
|
requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${encodeURIComponent(args.options.title)}')`;
|
|
31
32
|
}
|
|
32
|
-
|
|
33
|
+
let propertiesSelect = args.options.properties ? `?$select=${encodeURIComponent(args.options.properties)}` : ``;
|
|
34
|
+
propertiesSelect += args.options.withPermissions ? `${args.options.properties ? '&' : '?'}$expand=HasUniqueRoleAssignments,RoleAssignments/Member,RoleAssignments/RoleDefinitionBindings` : ``;
|
|
33
35
|
const requestOptions = {
|
|
34
36
|
url: requestUrl + propertiesSelect,
|
|
35
|
-
method: 'GET',
|
|
36
37
|
headers: {
|
|
37
38
|
'accept': 'application/json;odata=nometadata'
|
|
38
39
|
},
|
|
@@ -58,6 +59,9 @@ class SpoListGetCommand extends SpoCommand_1.default {
|
|
|
58
59
|
},
|
|
59
60
|
{
|
|
60
61
|
option: '-p, --properties [properties]'
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
option: '--withPermissions'
|
|
61
65
|
}
|
|
62
66
|
];
|
|
63
67
|
const parentOptions = super.options();
|
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Page = void 0;
|
|
3
|
+
exports.Page = exports.supportedPromoteAs = exports.supportedPageLayouts = void 0;
|
|
4
4
|
const request_1 = require("../../../../request");
|
|
5
5
|
const Utils_1 = require("../../../../Utils");
|
|
6
6
|
const clientsidepages_1 = require("./clientsidepages");
|
|
7
7
|
const pageMethods_1 = require("./pageMethods");
|
|
8
|
+
exports.supportedPageLayouts = ['Article', 'Home', 'SingleWebPartAppPage', 'RepostPage', 'HeaderlessSearchResults', 'Spaces', 'Topic'];
|
|
9
|
+
exports.supportedPromoteAs = ['HomePage', 'NewsPage', 'Template'];
|
|
8
10
|
class Page {
|
|
9
11
|
static getPage(name, webUrl, logger, debug, verbose) {
|
|
10
12
|
return new Promise((resolve, reject) => {
|
|
@@ -284,11 +284,11 @@ class SpoPageAddCommand extends SpoCommand_1.default {
|
|
|
284
284
|
},
|
|
285
285
|
{
|
|
286
286
|
option: '-l, --layoutType [layoutType]',
|
|
287
|
-
autocomplete:
|
|
287
|
+
autocomplete: Page_1.supportedPageLayouts
|
|
288
288
|
},
|
|
289
289
|
{
|
|
290
290
|
option: '-p, --promoteAs [promoteAs]',
|
|
291
|
-
autocomplete:
|
|
291
|
+
autocomplete: Page_1.supportedPromoteAs
|
|
292
292
|
},
|
|
293
293
|
{
|
|
294
294
|
option: '--commentsEnabled'
|
|
@@ -312,20 +312,17 @@ class SpoPageAddCommand extends SpoCommand_1.default {
|
|
|
312
312
|
return isValidSharePointUrl;
|
|
313
313
|
}
|
|
314
314
|
if (args.options.layoutType &&
|
|
315
|
-
args.options.layoutType
|
|
316
|
-
args.options.layoutType
|
|
317
|
-
return `${args.options.layoutType} is not a valid option for layoutType. Allowed values Article|Home`;
|
|
315
|
+
Page_1.supportedPageLayouts.indexOf(args.options.layoutType) < 0) {
|
|
316
|
+
return `${args.options.layoutType} is not a valid option for layoutType. Allowed values ${Page_1.supportedPageLayouts.join(', ')}`;
|
|
318
317
|
}
|
|
319
318
|
if (args.options.promoteAs &&
|
|
320
|
-
args.options.promoteAs
|
|
321
|
-
args.options.promoteAs
|
|
322
|
-
args.options.promoteAs !== 'Template') {
|
|
323
|
-
return `${args.options.promoteAs} is not a valid option for promoteAs. Allowed values HomePage|NewsPage|Template`;
|
|
319
|
+
Page_1.supportedPromoteAs.indexOf(args.options.promoteAs) < 0) {
|
|
320
|
+
return `${args.options.promoteAs} is not a valid option for promoteAs. Allowed values ${Page_1.supportedPromoteAs.join(', ')}`;
|
|
324
321
|
}
|
|
325
322
|
if (args.options.promoteAs === 'HomePage' && args.options.layoutType !== 'Home') {
|
|
326
323
|
return 'You can only promote home pages as site home page';
|
|
327
324
|
}
|
|
328
|
-
if (args.options.promoteAs === 'NewsPage' && args.options.layoutType
|
|
325
|
+
if (args.options.promoteAs === 'NewsPage' && args.options.layoutType && args.options.layoutType !== 'Article') {
|
|
329
326
|
return 'You can only promote article pages as news article';
|
|
330
327
|
}
|
|
331
328
|
return true;
|
|
@@ -283,11 +283,11 @@ class SpoPageSetCommand extends SpoCommand_1.default {
|
|
|
283
283
|
},
|
|
284
284
|
{
|
|
285
285
|
option: '-l, --layoutType [layoutType]',
|
|
286
|
-
autocomplete:
|
|
286
|
+
autocomplete: Page_1.supportedPageLayouts
|
|
287
287
|
},
|
|
288
288
|
{
|
|
289
289
|
option: '-p, --promoteAs [promoteAs]',
|
|
290
|
-
autocomplete:
|
|
290
|
+
autocomplete: Page_1.supportedPromoteAs
|
|
291
291
|
},
|
|
292
292
|
{
|
|
293
293
|
option: '--commentsEnabled [commentsEnabled]',
|
|
@@ -315,20 +315,17 @@ class SpoPageSetCommand extends SpoCommand_1.default {
|
|
|
315
315
|
return isValidSharePointUrl;
|
|
316
316
|
}
|
|
317
317
|
if (args.options.layoutType &&
|
|
318
|
-
args.options.layoutType
|
|
319
|
-
args.options.layoutType
|
|
320
|
-
return `${args.options.layoutType} is not a valid option for layoutType. Allowed values Article|Home`;
|
|
318
|
+
Page_1.supportedPageLayouts.indexOf(args.options.layoutType) < 0) {
|
|
319
|
+
return `${args.options.layoutType} is not a valid option for layoutType. Allowed values ${Page_1.supportedPageLayouts.join(', ')}`;
|
|
321
320
|
}
|
|
322
321
|
if (args.options.promoteAs &&
|
|
323
|
-
args.options.promoteAs
|
|
324
|
-
args.options.promoteAs
|
|
325
|
-
args.options.promoteAs !== 'Template') {
|
|
326
|
-
return `${args.options.promoteAs} is not a valid option for promoteAs. Allowed values HomePage|NewsPage|Template`;
|
|
322
|
+
Page_1.supportedPromoteAs.indexOf(args.options.promoteAs) < 0) {
|
|
323
|
+
return `${args.options.promoteAs} is not a valid option for promoteAs. Allowed values ${Page_1.supportedPromoteAs.join(', ')}`;
|
|
327
324
|
}
|
|
328
325
|
if (args.options.promoteAs === 'HomePage' && args.options.layoutType !== 'Home') {
|
|
329
326
|
return 'You can only promote home pages as site home page';
|
|
330
327
|
}
|
|
331
|
-
if (args.options.promoteAs === 'NewsPage' && args.options.layoutType
|
|
328
|
+
if (args.options.promoteAs === 'NewsPage' && args.options.layoutType && args.options.layoutType !== 'Article') {
|
|
332
329
|
return 'You can only promote article pages as news article';
|
|
333
330
|
}
|
|
334
331
|
if (typeof args.options.commentsEnabled !== 'undefined' &&
|
|
@@ -59,7 +59,7 @@ class SpoSiteEnsureCommand extends SpoCommand_1.default {
|
|
|
59
59
|
if (this.debug) {
|
|
60
60
|
logger.logToStderr(err.stderr);
|
|
61
61
|
}
|
|
62
|
-
if (err.error.message !== '
|
|
62
|
+
if (err.error.message !== '404 FILE NOT FOUND') {
|
|
63
63
|
return Promise.reject(err);
|
|
64
64
|
}
|
|
65
65
|
if (this.verbose) {
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const request_1 = require("../../../../request");
|
|
4
|
+
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
5
|
+
const commands_1 = require("../../commands");
|
|
6
|
+
class SpoSiteRecycleBinItemListCommand extends SpoCommand_1.default {
|
|
7
|
+
get name() {
|
|
8
|
+
return commands_1.default.SITE_RECYCLEBINITEM_LIST;
|
|
9
|
+
}
|
|
10
|
+
get description() {
|
|
11
|
+
return 'Lists items from recycle bin';
|
|
12
|
+
}
|
|
13
|
+
defaultProperties() {
|
|
14
|
+
return ['Id', 'Title', 'DirName'];
|
|
15
|
+
}
|
|
16
|
+
commandAction(logger, args, cb) {
|
|
17
|
+
if (this.verbose) {
|
|
18
|
+
logger.logToStderr(`Retrieving all items from recycle bin at ${args.options.siteUrl}...`);
|
|
19
|
+
}
|
|
20
|
+
const state = args.options.secondary ? '2' : '1';
|
|
21
|
+
let requestUrl = `${args.options.siteUrl}/_api/site/RecycleBin?$filter=(ItemState eq ${state})`;
|
|
22
|
+
if (typeof args.options.type !== 'undefined') {
|
|
23
|
+
const type = SpoSiteRecycleBinItemListCommand.recycleBinItemType.find(item => item.value === args.options.type);
|
|
24
|
+
if (typeof type !== 'undefined') {
|
|
25
|
+
requestUrl += ` and (ItemType eq ${type.id})`;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
const requestOptions = {
|
|
29
|
+
url: requestUrl,
|
|
30
|
+
headers: {
|
|
31
|
+
'accept': 'application/json;odata=nometadata'
|
|
32
|
+
},
|
|
33
|
+
responseType: 'json'
|
|
34
|
+
};
|
|
35
|
+
request_1.default
|
|
36
|
+
.get(requestOptions)
|
|
37
|
+
.then((response) => {
|
|
38
|
+
logger.log(response.value);
|
|
39
|
+
cb();
|
|
40
|
+
}, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
|
|
41
|
+
}
|
|
42
|
+
options() {
|
|
43
|
+
const options = [
|
|
44
|
+
{
|
|
45
|
+
option: '-u, --siteUrl <siteUrl>'
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
option: '-t, --type [type]',
|
|
49
|
+
autocomplete: SpoSiteRecycleBinItemListCommand.recycleBinItemType.map(item => item.value)
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
option: '-s, --secondary'
|
|
53
|
+
}
|
|
54
|
+
];
|
|
55
|
+
const parentOptions = super.options();
|
|
56
|
+
return options.concat(parentOptions);
|
|
57
|
+
}
|
|
58
|
+
validate(args) {
|
|
59
|
+
const isValidSharePointUrl = SpoCommand_1.default.isValidSharePointUrl(args.options.siteUrl);
|
|
60
|
+
if (isValidSharePointUrl !== true) {
|
|
61
|
+
return isValidSharePointUrl;
|
|
62
|
+
}
|
|
63
|
+
if (typeof args.options.type !== 'undefined' &&
|
|
64
|
+
!SpoSiteRecycleBinItemListCommand.recycleBinItemType.some(item => item.value === args.options.type)) {
|
|
65
|
+
return `${args.options.type} is not a valid value. Allowed values are ${SpoSiteRecycleBinItemListCommand.recycleBinItemType.map(item => item.value).join(', ')}`;
|
|
66
|
+
}
|
|
67
|
+
return true;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
SpoSiteRecycleBinItemListCommand.recycleBinItemType = [
|
|
71
|
+
{ id: 1, value: 'files' },
|
|
72
|
+
{ id: 3, value: 'listItems' },
|
|
73
|
+
{ id: 5, value: 'folders' }
|
|
74
|
+
];
|
|
75
|
+
module.exports = new SpoSiteRecycleBinItemListCommand();
|
|
76
|
+
//# sourceMappingURL=site-recyclebinitem-list.js.map
|
|
@@ -25,26 +25,65 @@ class SpoSiteRemoveCommand extends SpoCommand_1.default {
|
|
|
25
25
|
commandAction(logger, args, cb) {
|
|
26
26
|
const removeSite = () => {
|
|
27
27
|
this.dots = '';
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
28
|
+
if (args.options.fromRecycleBin) {
|
|
29
|
+
this
|
|
30
|
+
.deleteSiteWithoutGroup(logger, args)
|
|
31
|
+
.then(_ => cb(), (err) => this.handleRejectedPromise(err, logger, cb));
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
this
|
|
35
|
+
.getSiteGroupId(args.options.url, logger)
|
|
36
|
+
.then((groupId) => {
|
|
37
|
+
if (groupId === '00000000-0000-0000-0000-000000000000') {
|
|
38
|
+
if (this.debug) {
|
|
39
|
+
logger.logToStderr('Site is not groupified. Going ahead with the conventional site deletion options');
|
|
40
|
+
}
|
|
41
|
+
return this.deleteSiteWithoutGroup(logger, args);
|
|
40
42
|
}
|
|
41
|
-
|
|
42
|
-
|
|
43
|
+
else {
|
|
44
|
+
if (this.debug) {
|
|
45
|
+
logger.logToStderr(`Site attached to group ${groupId}. Initiating group delete operation via Graph API`);
|
|
46
|
+
}
|
|
47
|
+
return this
|
|
48
|
+
.getSiteGroup(groupId)
|
|
49
|
+
.then((group) => {
|
|
50
|
+
if (args.options.skipRecycleBin || args.options.wait) {
|
|
51
|
+
logger.logToStderr(chalk.yellow(`Entered site is a groupified site. Hence, the parameters 'skipRecycleBin' and 'wait' will not be applicable.`));
|
|
52
|
+
}
|
|
53
|
+
return this.deleteGroupifiedSite(group.id, logger);
|
|
54
|
+
})
|
|
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();
|
|
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));
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
return Promise.reject(err);
|
|
81
|
+
}
|
|
82
|
+
});
|
|
43
83
|
}
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
}
|
|
47
|
-
.then(_ => cb(), (err) => this.handleRejectedPromise(err, logger, cb));
|
|
84
|
+
})
|
|
85
|
+
.then(_ => cb(), (err) => this.handleRejectedPromise(err, logger, cb));
|
|
86
|
+
}
|
|
48
87
|
};
|
|
49
88
|
if (args.options.confirm) {
|
|
50
89
|
removeSite();
|
|
@@ -65,32 +104,64 @@ class SpoSiteRemoveCommand extends SpoCommand_1.default {
|
|
|
65
104
|
});
|
|
66
105
|
}
|
|
67
106
|
}
|
|
107
|
+
getSiteGroup(groupId) {
|
|
108
|
+
const requestOptions = {
|
|
109
|
+
url: `https://graph.microsoft.com/v1.0/groups/${groupId}`,
|
|
110
|
+
headers: {
|
|
111
|
+
accept: 'application/json;odata.metadata=none'
|
|
112
|
+
},
|
|
113
|
+
responseType: 'json'
|
|
114
|
+
};
|
|
115
|
+
return request_1.default.get(requestOptions);
|
|
116
|
+
}
|
|
117
|
+
isSiteGroupDeleted(groupId) {
|
|
118
|
+
const requestOptions = {
|
|
119
|
+
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}')`,
|
|
120
|
+
headers: {
|
|
121
|
+
accept: 'application/json;odata.metadata=none'
|
|
122
|
+
},
|
|
123
|
+
responseType: 'json'
|
|
124
|
+
};
|
|
125
|
+
return request_1.default.get(requestOptions);
|
|
126
|
+
}
|
|
127
|
+
deleteOrphanedSite(logger, url) {
|
|
128
|
+
return this
|
|
129
|
+
.getSpoAdminUrl(logger, this.debug)
|
|
130
|
+
.then((spoAdminUrl) => {
|
|
131
|
+
const requestOptions = {
|
|
132
|
+
url: `${spoAdminUrl}/_api/GroupSiteManager/Delete?siteUrl='${url}'`,
|
|
133
|
+
headers: {
|
|
134
|
+
'content-type': 'application/json;odata=nometadata',
|
|
135
|
+
accept: 'application/json;odata=nometadata'
|
|
136
|
+
},
|
|
137
|
+
responseType: 'json'
|
|
138
|
+
};
|
|
139
|
+
return request_1.default.post(requestOptions);
|
|
140
|
+
});
|
|
141
|
+
}
|
|
68
142
|
deleteSiteWithoutGroup(logger, args) {
|
|
69
143
|
return this
|
|
70
144
|
.getSpoAdminUrl(logger, this.debug)
|
|
71
|
-
.then((
|
|
72
|
-
this.spoAdminUrl =
|
|
145
|
+
.then((spoAdminUrl) => {
|
|
146
|
+
this.spoAdminUrl = spoAdminUrl;
|
|
73
147
|
return this.ensureFormDigest(this.spoAdminUrl, logger, this.context, this.debug);
|
|
74
148
|
})
|
|
75
149
|
.then((res) => {
|
|
76
150
|
this.context = res;
|
|
77
151
|
if (args.options.fromRecycleBin) {
|
|
78
152
|
if (this.verbose) {
|
|
79
|
-
logger.logToStderr(`Deleting site
|
|
153
|
+
logger.logToStderr(`Deleting site from recycle bin ${args.options.url}...`);
|
|
80
154
|
}
|
|
81
155
|
return this.deleteSiteFromTheRecycleBin(args.options.url, args.options.wait, logger);
|
|
82
156
|
}
|
|
83
157
|
else {
|
|
84
|
-
if (this.verbose) {
|
|
85
|
-
logger.logToStderr(`Deleting site collection ${args.options.url}...`);
|
|
86
|
-
}
|
|
87
158
|
return this.deleteSite(args.options.url, args.options.wait, logger);
|
|
88
159
|
}
|
|
89
160
|
})
|
|
90
161
|
.then(() => {
|
|
91
162
|
if (args.options.skipRecycleBin) {
|
|
92
163
|
if (this.verbose) {
|
|
93
|
-
logger.logToStderr(`Also deleting site
|
|
164
|
+
logger.logToStderr(`Also deleting site from tenant recycle bin ${args.options.url}...`);
|
|
94
165
|
}
|
|
95
166
|
return this.deleteSiteFromTheRecycleBin(args.options.url, args.options.wait, logger);
|
|
96
167
|
}
|
|
@@ -106,7 +177,7 @@ class SpoSiteRemoveCommand extends SpoCommand_1.default {
|
|
|
106
177
|
.then((res) => {
|
|
107
178
|
this.context = res;
|
|
108
179
|
if (this.verbose) {
|
|
109
|
-
logger.logToStderr(`Deleting site ${url}
|
|
180
|
+
logger.logToStderr(`Deleting site ${url}...`);
|
|
110
181
|
}
|
|
111
182
|
const requestOptions = {
|
|
112
183
|
url: `${this.spoAdminUrl}/_vti_bin/client.svc/ProcessQuery`,
|
|
@@ -143,9 +214,6 @@ class SpoSiteRemoveCommand extends SpoCommand_1.default {
|
|
|
143
214
|
.ensureFormDigest(this.spoAdminUrl, logger, this.context, this.debug)
|
|
144
215
|
.then((res) => {
|
|
145
216
|
this.context = res;
|
|
146
|
-
if (this.verbose) {
|
|
147
|
-
logger.logToStderr(`Deleting site ${url} from the recycle bin...`);
|
|
148
|
-
}
|
|
149
217
|
const requestOptions = {
|
|
150
218
|
url: `${this.spoAdminUrl}/_vti_bin/client.svc/ProcessQuery`,
|
|
151
219
|
headers: {
|
|
@@ -185,7 +253,7 @@ class SpoSiteRemoveCommand extends SpoCommand_1.default {
|
|
|
185
253
|
.then((res) => {
|
|
186
254
|
this.context = res;
|
|
187
255
|
if (this.verbose) {
|
|
188
|
-
logger.logToStderr(`Retrieving the
|
|
256
|
+
logger.logToStderr(`Retrieving the group Id of the site ${url}`);
|
|
189
257
|
}
|
|
190
258
|
const requestOptions = {
|
|
191
259
|
url: `${this.spoAdminUrl}/_vti_bin/client.svc/ProcessQuery`,
|