@pnp/cli-microsoft365 5.3.0-beta.e83e121 → 5.3.0-beta.ebb13d0
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/dist/Auth.js +5 -0
- package/dist/m365/aad/commands/app/app-add.js +91 -35
- package/dist/m365/aad/commands/app/app-role-list.js +1 -1
- package/dist/m365/aad/commands/app/app-set.js +91 -0
- package/dist/m365/aad/commands/group/group-list.js +1 -1
- package/dist/m365/aad/commands/groupsetting/groupsetting-list.js +1 -1
- package/dist/m365/aad/commands/groupsettingtemplate/groupsettingtemplate-get.js +1 -1
- package/dist/m365/aad/commands/groupsettingtemplate/groupsettingtemplate-list.js +1 -1
- package/dist/m365/aad/commands/o365group/o365group-conversation-list.js +1 -1
- package/dist/m365/aad/commands/o365group/o365group-conversation-post-list.js +1 -1
- package/dist/m365/aad/commands/o365group/o365group-list.js +1 -1
- package/dist/m365/aad/commands/o365group/o365group-recyclebinitem-clear.js +3 -3
- package/dist/m365/aad/commands/o365group/o365group-recyclebinitem-list.js +1 -1
- package/dist/m365/aad/commands/o365group/o365group-user-list.js +2 -2
- package/dist/m365/aad/commands/o365group/o365group-user-set.js +2 -2
- package/dist/m365/aad/commands/user/user-list.js +1 -1
- package/dist/m365/aad/commands/user/user-signin-list.js +1 -1
- package/dist/m365/base/PowerBICommand.js +10 -0
- package/dist/m365/file/commands/file-list.js +1 -1
- package/dist/m365/outlook/commands/message/message-list.js +1 -1
- package/dist/m365/outlook/commands/room/room-list.js +1 -1
- package/dist/m365/outlook/commands/roomlist/roomlist-list.js +1 -1
- package/dist/m365/planner/commands/bucket/bucket-add.js +8 -16
- package/dist/m365/planner/commands/bucket/bucket-get.js +8 -20
- package/dist/m365/planner/commands/bucket/bucket-list.js +10 -19
- package/dist/m365/planner/commands/bucket/bucket-remove.js +8 -20
- package/dist/m365/planner/commands/bucket/bucket-set.js +9 -21
- package/dist/m365/planner/commands/plan/plan-add.js +6 -1
- package/dist/m365/planner/commands/plan/plan-details-get.js +12 -15
- package/dist/m365/planner/commands/plan/plan-get.js +13 -18
- package/dist/m365/planner/commands/plan/plan-list.js +10 -13
- package/dist/m365/planner/commands/task/task-add.js +8 -16
- package/dist/m365/planner/commands/task/task-details-get.js +6 -0
- package/dist/m365/planner/commands/task/task-get.js +11 -23
- package/dist/m365/planner/commands/task/task-list.js +15 -24
- package/dist/m365/planner/commands/task/task-reference-add.js +75 -0
- package/dist/m365/planner/commands/task/task-reference-list.js +45 -0
- package/dist/m365/planner/commands/task/task-set.js +9 -18
- package/dist/m365/planner/commands.js +3 -1
- package/dist/m365/pp/commands/gateway/gateway-list.js +36 -0
- package/dist/m365/pp/commands/managementapp/managementapp-list.js +1 -1
- package/dist/m365/pp/commands.js +1 -0
- package/dist/m365/spo/commands/listitem/listitem-roleinheritance-break.js +83 -0
- package/dist/m365/spo/commands/listitem/listitem-roleinheritance-reset.js +79 -0
- package/dist/m365/spo/commands.js +2 -0
- package/dist/m365/teams/commands/app/app-list.js +1 -1
- package/dist/m365/teams/commands/channel/channel-list.js +1 -1
- package/dist/m365/teams/commands/channel/channel-member-add.js +4 -1
- package/dist/m365/teams/commands/channel/channel-member-list.js +1 -1
- package/dist/m365/teams/commands/channel/channel-member-remove.js +3 -0
- package/dist/m365/teams/commands/channel/channel-member-set.js +3 -0
- package/dist/m365/teams/commands/chat/chat-get.js +8 -8
- package/dist/m365/teams/commands/chat/chat-list.js +1 -1
- package/dist/m365/teams/commands/chat/chat-member-list.js +1 -1
- package/dist/m365/teams/commands/chat/chat-message-list.js +1 -1
- package/dist/m365/teams/commands/chat/chat-message-send.js +6 -6
- package/dist/m365/teams/commands/chat/chatUtil.js +4 -4
- package/dist/m365/teams/commands/message/message-list.js +1 -1
- package/dist/m365/teams/commands/message/message-reply-list.js +1 -1
- package/dist/m365/teams/commands/tab/tab-list.js +1 -1
- package/dist/m365/teams/commands/team/team-list.js +1 -1
- package/dist/m365/teams/commands/user/user-app-list.js +1 -1
- package/dist/m365/teams/commands/user/user-list.js +2 -2
- package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-healthissue-list.js +1 -1
- package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-message-list.js +1 -1
- package/dist/m365/todo/commands/list/list-list.js +1 -1
- package/dist/m365/todo/commands/task/task-list.js +1 -1
- package/dist/utils/accessToken.js +18 -0
- package/dist/utils/formatting.js +11 -2
- package/dist/utils/odata.js +2 -2
- package/dist/utils/planner.js +65 -0
- package/docs/docs/cmd/aad/app/app-add.md +15 -0
- package/docs/docs/cmd/aad/app/app-set.md +17 -0
- package/docs/docs/cmd/aad/approleassignment/approleassignment-remove.md +1 -1
- package/docs/docs/cmd/planner/task/task-reference-add.md +45 -0
- package/docs/docs/cmd/planner/task/task-reference-list.md +24 -0
- package/docs/docs/cmd/pp/gateway/gateway-list.md +21 -0
- package/docs/docs/cmd/spo/listitem/listitem-roleinheritance-break.md +58 -0
- package/docs/docs/cmd/spo/listitem/listitem-roleinheritance-reset.md +39 -0
- package/docs/docs/cmd/spo/userprofile/userprofile-get.md +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const request_1 = require("../../../../request");
|
|
4
|
+
const GraphCommand_1 = require("../../../base/GraphCommand");
|
|
5
|
+
const commands_1 = require("../../commands");
|
|
6
|
+
const utils_1 = require("../../../../utils");
|
|
7
|
+
const Auth_1 = require("../../../../Auth");
|
|
8
|
+
class PlannerTaskReferenceListCommand extends GraphCommand_1.default {
|
|
9
|
+
get name() {
|
|
10
|
+
return commands_1.default.TASK_REFERENCE_LIST;
|
|
11
|
+
}
|
|
12
|
+
get description() {
|
|
13
|
+
return 'Retrieve the references of the specified planner task';
|
|
14
|
+
}
|
|
15
|
+
commandAction(logger, args, cb) {
|
|
16
|
+
if (utils_1.accessToken.isAppOnlyAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken)) {
|
|
17
|
+
this.handleError('This command does not support application permissions.', logger, cb);
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
const requestOptions = {
|
|
21
|
+
url: `${this.resource}/v1.0/planner/tasks/${encodeURIComponent(args.options.taskId)}/details?$select=references`,
|
|
22
|
+
headers: {
|
|
23
|
+
accept: 'application/json;odata.metadata=none'
|
|
24
|
+
},
|
|
25
|
+
responseType: 'json'
|
|
26
|
+
};
|
|
27
|
+
request_1.default
|
|
28
|
+
.get(requestOptions)
|
|
29
|
+
.then((res) => {
|
|
30
|
+
logger.log(res.references);
|
|
31
|
+
cb();
|
|
32
|
+
}, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
|
|
33
|
+
}
|
|
34
|
+
options() {
|
|
35
|
+
const options = [
|
|
36
|
+
{
|
|
37
|
+
option: '-i, --taskId <taskId>'
|
|
38
|
+
}
|
|
39
|
+
];
|
|
40
|
+
const parentOptions = super.options();
|
|
41
|
+
return options.concat(parentOptions);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
module.exports = new PlannerTaskReferenceListCommand();
|
|
45
|
+
//# sourceMappingURL=task-reference-list.js.map
|
|
@@ -1,7 +1,9 @@
|
|
|
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 Auth_1 = require("../../../../Auth");
|
|
5
|
+
const request_1 = require("../../../../request");
|
|
6
|
+
const planner_1 = require("../../../../utils/planner");
|
|
5
7
|
const GraphCommand_1 = require("../../../base/GraphCommand");
|
|
6
8
|
const commands_1 = require("../../commands");
|
|
7
9
|
class PlannerTaskSetCommand extends GraphCommand_1.default {
|
|
@@ -36,6 +38,10 @@ class PlannerTaskSetCommand extends GraphCommand_1.default {
|
|
|
36
38
|
return telemetryProps;
|
|
37
39
|
}
|
|
38
40
|
commandAction(logger, args, cb) {
|
|
41
|
+
if (utils_1.accessToken.isAppOnlyAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken)) {
|
|
42
|
+
this.handleError('This command does not support application permissions.', logger, cb);
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
39
45
|
this
|
|
40
46
|
.getBucketId(args.options)
|
|
41
47
|
.then(bucketId => {
|
|
@@ -217,23 +223,8 @@ class PlannerTaskSetCommand extends GraphCommand_1.default {
|
|
|
217
223
|
}
|
|
218
224
|
return this
|
|
219
225
|
.getGroupId(options)
|
|
220
|
-
.then((groupId) =>
|
|
221
|
-
|
|
222
|
-
url: `${this.resource}/v1.0/planner/plans?$filter=(owner eq '${groupId}')&$select=id,title`,
|
|
223
|
-
headers: {
|
|
224
|
-
accept: 'application/json;odata.metadata=none'
|
|
225
|
-
},
|
|
226
|
-
responseType: 'json'
|
|
227
|
-
};
|
|
228
|
-
return request_1.default.get(requestOptions);
|
|
229
|
-
})
|
|
230
|
-
.then((response) => {
|
|
231
|
-
const plan = response.value.find(val => val.title === options.planName);
|
|
232
|
-
if (!plan) {
|
|
233
|
-
return Promise.reject(`The specified plan does not exist`);
|
|
234
|
-
}
|
|
235
|
-
return Promise.resolve(plan.id);
|
|
236
|
-
});
|
|
226
|
+
.then((groupId) => planner_1.planner.getPlanByName(options.planName, groupId))
|
|
227
|
+
.then(plan => plan.id);
|
|
237
228
|
}
|
|
238
229
|
getGroupId(options) {
|
|
239
230
|
if (options.ownerGroupId) {
|
|
@@ -8,13 +8,15 @@ exports.default = {
|
|
|
8
8
|
BUCKET_REMOVE: `${prefix} bucket remove`,
|
|
9
9
|
BUCKET_GET: `${prefix} bucket get`,
|
|
10
10
|
PLAN_ADD: `${prefix} plan add`,
|
|
11
|
-
PLAN_GET: `${prefix} plan get`,
|
|
12
11
|
PLAN_DETAILS_GET: `${prefix} plan details get`,
|
|
12
|
+
PLAN_GET: `${prefix} plan get`,
|
|
13
13
|
PLAN_LIST: `${prefix} plan list`,
|
|
14
14
|
TASK_ADD: `${prefix} task add`,
|
|
15
15
|
TASK_DETAILS_GET: `${prefix} task details get`,
|
|
16
16
|
TASK_GET: `${prefix} task get`,
|
|
17
17
|
TASK_LIST: `${prefix} task list`,
|
|
18
|
+
TASK_REFERENCE_ADD: `${prefix} task reference add`,
|
|
19
|
+
TASK_REFERENCE_LIST: `${prefix} task reference list`,
|
|
18
20
|
TASK_SET: `${prefix} task set`
|
|
19
21
|
};
|
|
20
22
|
//# sourceMappingURL=commands.js.map
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const request_1 = require("../../../../request");
|
|
4
|
+
const PowerBICommand_1 = require("../../../base/PowerBICommand");
|
|
5
|
+
const commands_1 = require("../../commands");
|
|
6
|
+
class PpGatewayListCommand extends PowerBICommand_1.default {
|
|
7
|
+
get name() {
|
|
8
|
+
return commands_1.default.GATEWAY_LIST;
|
|
9
|
+
}
|
|
10
|
+
get description() {
|
|
11
|
+
return 'Returns a list of gateways for which the user is an admin';
|
|
12
|
+
}
|
|
13
|
+
defaultProperties() {
|
|
14
|
+
return ['id', 'name'];
|
|
15
|
+
}
|
|
16
|
+
commandAction(logger, args, cb) {
|
|
17
|
+
if (this.verbose) {
|
|
18
|
+
logger.logToStderr(`Retrieving list of gateways for which the user is an admin...`);
|
|
19
|
+
}
|
|
20
|
+
const requestOptions = {
|
|
21
|
+
url: `${this.resource}/v1.0/myorg/gateways`,
|
|
22
|
+
headers: {
|
|
23
|
+
accept: 'application/json;odata.metadata=none'
|
|
24
|
+
},
|
|
25
|
+
responseType: 'json'
|
|
26
|
+
};
|
|
27
|
+
request_1.default
|
|
28
|
+
.get(requestOptions)
|
|
29
|
+
.then((res) => {
|
|
30
|
+
logger.log(res.value);
|
|
31
|
+
cb();
|
|
32
|
+
}, (rawRes) => this.handleRejectedODataJsonPromise(rawRes, logger, cb));
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
module.exports = new PpGatewayListCommand();
|
|
36
|
+
//# sourceMappingURL=gateway-list.js.map
|
|
@@ -13,7 +13,7 @@ class PpManagementAppListCommand extends PowerPlatformCommand_1.default {
|
|
|
13
13
|
commandAction(logger, args, cb) {
|
|
14
14
|
const endpoint = `${this.resource}/providers/Microsoft.BusinessAppPlatform/adminApplications?api-version=2020-06-01`;
|
|
15
15
|
utils_1.odata
|
|
16
|
-
.getAllItems(endpoint
|
|
16
|
+
.getAllItems(endpoint)
|
|
17
17
|
.then((managementApps) => {
|
|
18
18
|
logger.log(managementApps);
|
|
19
19
|
cb();
|
package/dist/m365/pp/commands.js
CHANGED
|
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
const prefix = 'pp';
|
|
4
4
|
exports.default = {
|
|
5
5
|
ENVIRONMENT_LIST: `${prefix} environment list`,
|
|
6
|
+
GATEWAY_LIST: `${prefix} gateway list`,
|
|
6
7
|
MANAGEMENTAPP_ADD: `${prefix} managementapp add`,
|
|
7
8
|
MANAGEMENTAPP_LIST: `${prefix} managementapp list`
|
|
8
9
|
};
|
|
@@ -0,0 +1,83 @@
|
|
|
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 SpoListItemRoleInheritanceBreakCommand extends SpoCommand_1.default {
|
|
8
|
+
get name() {
|
|
9
|
+
return commands_1.default.LISTITEM_ROLEINHERITANCE_BREAK;
|
|
10
|
+
}
|
|
11
|
+
get description() {
|
|
12
|
+
return 'Break inheritance of list item';
|
|
13
|
+
}
|
|
14
|
+
optionSets() {
|
|
15
|
+
return [
|
|
16
|
+
['listId', 'listTitle']
|
|
17
|
+
];
|
|
18
|
+
}
|
|
19
|
+
commandAction(logger, args, cb) {
|
|
20
|
+
if (this.verbose) {
|
|
21
|
+
logger.logToStderr(`Breaking role inheritance of list item in site at ${args.options.webUrl}...`);
|
|
22
|
+
}
|
|
23
|
+
let requestUrl = `${args.options.webUrl}/_api/web/lists`;
|
|
24
|
+
if (args.options.listId) {
|
|
25
|
+
requestUrl += `(guid'${encodeURIComponent(args.options.listId)}')`;
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
requestUrl += `/getbytitle('${encodeURIComponent(args.options.listTitle)}')`;
|
|
29
|
+
}
|
|
30
|
+
let keepExistingPermissions = true;
|
|
31
|
+
if (args.options.clearExistingPermissions) {
|
|
32
|
+
keepExistingPermissions = !args.options.clearExistingPermissions;
|
|
33
|
+
}
|
|
34
|
+
const requestOptions = {
|
|
35
|
+
url: `${requestUrl}/items(${args.options.listItemId})/breakroleinheritance(${keepExistingPermissions})`,
|
|
36
|
+
method: 'POST',
|
|
37
|
+
headers: {
|
|
38
|
+
'accept': 'application/json;odata=nometadata',
|
|
39
|
+
'content-type': 'application/json'
|
|
40
|
+
},
|
|
41
|
+
responseType: 'json'
|
|
42
|
+
};
|
|
43
|
+
request_1.default
|
|
44
|
+
.post(requestOptions)
|
|
45
|
+
.then(_ => cb(), (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
|
|
46
|
+
}
|
|
47
|
+
options() {
|
|
48
|
+
const options = [
|
|
49
|
+
{
|
|
50
|
+
option: '-u, --webUrl <webUrl>'
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
option: '--listItemId <listItemId>'
|
|
54
|
+
},
|
|
55
|
+
{
|
|
56
|
+
option: '-l, --listId [listId]'
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
option: '-t, --listTitle [listTitle]'
|
|
60
|
+
},
|
|
61
|
+
{
|
|
62
|
+
option: '-c, --clearExistingPermissions'
|
|
63
|
+
}
|
|
64
|
+
];
|
|
65
|
+
const parentOptions = super.options();
|
|
66
|
+
return options.concat(parentOptions);
|
|
67
|
+
}
|
|
68
|
+
validate(args) {
|
|
69
|
+
const isValidSharePointUrl = utils_1.validation.isValidSharePointUrl(args.options.webUrl);
|
|
70
|
+
if (isValidSharePointUrl !== true) {
|
|
71
|
+
return isValidSharePointUrl;
|
|
72
|
+
}
|
|
73
|
+
if (args.options.listId && !utils_1.validation.isValidGuid(args.options.listId)) {
|
|
74
|
+
return `${args.options.listId} is not a valid GUID`;
|
|
75
|
+
}
|
|
76
|
+
if (isNaN(args.options.listItemId)) {
|
|
77
|
+
return `${args.options.listItemId} is not a number`;
|
|
78
|
+
}
|
|
79
|
+
return true;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
module.exports = new SpoListItemRoleInheritanceBreakCommand();
|
|
83
|
+
//# sourceMappingURL=listitem-roleinheritance-break.js.map
|
|
@@ -0,0 +1,79 @@
|
|
|
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 SpoListItemRoleInheritanceResetCommand extends SpoCommand_1.default {
|
|
8
|
+
get name() {
|
|
9
|
+
return commands_1.default.LISTITEM_ROLEINHERITANCE_RESET;
|
|
10
|
+
}
|
|
11
|
+
get description() {
|
|
12
|
+
return 'Restores the role inheritance of list item, file, or folder';
|
|
13
|
+
}
|
|
14
|
+
getTelemetryProperties(args) {
|
|
15
|
+
const telemetryProps = super.getTelemetryProperties(args);
|
|
16
|
+
telemetryProps.listId = typeof args.options.listId !== 'undefined';
|
|
17
|
+
telemetryProps.listTitle = typeof args.options.listTitle !== 'undefined';
|
|
18
|
+
return telemetryProps;
|
|
19
|
+
}
|
|
20
|
+
commandAction(logger, args, cb) {
|
|
21
|
+
let requestUrl = `${args.options.webUrl}/_api/web/lists`;
|
|
22
|
+
if (args.options.listId) {
|
|
23
|
+
requestUrl += `(guid'${encodeURIComponent(args.options.listId)}')`;
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
requestUrl += `/getbytitle('${encodeURIComponent(args.options.listTitle)}')`;
|
|
27
|
+
}
|
|
28
|
+
const requestOptions = {
|
|
29
|
+
url: `${requestUrl}/items(${args.options.listItemId})/resetroleinheritance`,
|
|
30
|
+
method: 'POST',
|
|
31
|
+
headers: {
|
|
32
|
+
'accept': 'application/json;odata=nometadata',
|
|
33
|
+
'content-type': 'application/json'
|
|
34
|
+
},
|
|
35
|
+
responseType: 'json'
|
|
36
|
+
};
|
|
37
|
+
request_1.default
|
|
38
|
+
.post(requestOptions)
|
|
39
|
+
.then(_ => cb(), (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
|
|
40
|
+
}
|
|
41
|
+
optionSets() {
|
|
42
|
+
return [
|
|
43
|
+
['listId', 'listTitle']
|
|
44
|
+
];
|
|
45
|
+
}
|
|
46
|
+
options() {
|
|
47
|
+
const options = [
|
|
48
|
+
{
|
|
49
|
+
option: '-u, --webUrl <webUrl>'
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
option: '--listItemId <listItemId>'
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
option: '--listId [listId]'
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
option: '--listTitle [listTitle]'
|
|
59
|
+
}
|
|
60
|
+
];
|
|
61
|
+
const parentOptions = super.options();
|
|
62
|
+
return options.concat(parentOptions);
|
|
63
|
+
}
|
|
64
|
+
validate(args) {
|
|
65
|
+
const isValidSharePointUrl = utils_1.validation.isValidSharePointUrl(args.options.webUrl);
|
|
66
|
+
if (isValidSharePointUrl !== true) {
|
|
67
|
+
return isValidSharePointUrl;
|
|
68
|
+
}
|
|
69
|
+
if (args.options.listId && !utils_1.validation.isValidGuid(args.options.listId)) {
|
|
70
|
+
return `${args.options.listId} is not a valid GUID`;
|
|
71
|
+
}
|
|
72
|
+
if (isNaN(args.options.listItemId)) {
|
|
73
|
+
return `${args.options.listItemId} is not a number`;
|
|
74
|
+
}
|
|
75
|
+
return true;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
module.exports = new SpoListItemRoleInheritanceResetCommand();
|
|
79
|
+
//# sourceMappingURL=listitem-roleinheritance-reset.js.map
|
|
@@ -120,6 +120,8 @@ exports.default = {
|
|
|
120
120
|
LISTITEM_RECORD_DECLARE: `${prefix} listitem record declare`,
|
|
121
121
|
LISTITEM_RECORD_UNDECLARE: `${prefix} listitem record undeclare`,
|
|
122
122
|
LISTITEM_REMOVE: `${prefix} listitem remove`,
|
|
123
|
+
LISTITEM_ROLEINHERITANCE_BREAK: `${prefix} listitem roleinheritance break`,
|
|
124
|
+
LISTITEM_ROLEINHERITANCE_RESET: `${prefix} listitem roleinheritance reset`,
|
|
123
125
|
LISTITEM_SET: `${prefix} listitem set`,
|
|
124
126
|
MAIL_SEND: `${prefix} mail send`,
|
|
125
127
|
NAVIGATION_NODE_ADD: `${prefix} navigation node add`,
|
|
@@ -76,7 +76,7 @@ class TeamsAppListCommand extends GraphCommand_1.default {
|
|
|
76
76
|
commandAction(logger, args, cb) {
|
|
77
77
|
this
|
|
78
78
|
.getEndpointUrl(args)
|
|
79
|
-
.then(endpoint => utils_1.odata.getAllItems(endpoint
|
|
79
|
+
.then(endpoint => utils_1.odata.getAllItems(endpoint))
|
|
80
80
|
.then((items) => {
|
|
81
81
|
if (args.options.teamId || args.options.teamName) {
|
|
82
82
|
items.forEach(t => {
|
|
@@ -53,7 +53,7 @@ class TeamsChannelListCommand extends GraphCommand_1.default {
|
|
|
53
53
|
if (args.options.type) {
|
|
54
54
|
endpoint += `?$filter=membershipType eq '${args.options.type}'`;
|
|
55
55
|
}
|
|
56
|
-
return utils_1.odata.getAllItems(endpoint
|
|
56
|
+
return utils_1.odata.getAllItems(endpoint);
|
|
57
57
|
})
|
|
58
58
|
.then((items) => {
|
|
59
59
|
logger.log(items);
|
|
@@ -153,8 +153,11 @@ class TeamsChannelMemberAddCommand extends GraphCommand_1.default {
|
|
|
153
153
|
if (!channelItem) {
|
|
154
154
|
return Promise.reject(`The specified channel '${args.options.channelName}' does not exist in the Microsoft Teams team with ID '${teamId}'`);
|
|
155
155
|
}
|
|
156
|
+
if (channelItem.membershipType !== "private") {
|
|
157
|
+
return Promise.reject(`The specified channel is not a private channel`);
|
|
158
|
+
}
|
|
156
159
|
return Promise.resolve(channelItem.id);
|
|
157
|
-
}
|
|
160
|
+
});
|
|
158
161
|
}
|
|
159
162
|
getUserId(args) {
|
|
160
163
|
if (args.options.userId) {
|
|
@@ -40,7 +40,7 @@ class TeamsChannelMemberListCommand extends GraphCommand_1.default {
|
|
|
40
40
|
})
|
|
41
41
|
.then((channelId) => {
|
|
42
42
|
const endpoint = `${this.resource}/v1.0/teams/${this.teamId}/channels/${channelId}/members`;
|
|
43
|
-
return utils_1.odata.getAllItems(endpoint
|
|
43
|
+
return utils_1.odata.getAllItems(endpoint);
|
|
44
44
|
})
|
|
45
45
|
.then((memberships) => {
|
|
46
46
|
if (args.options.role) {
|
|
@@ -135,6 +135,9 @@ class TeamsChannelMemberRemoveCommand extends GraphCommand_1.default {
|
|
|
135
135
|
if (!channelItem) {
|
|
136
136
|
return Promise.reject(`The specified channel does not exist in the Microsoft Teams team`);
|
|
137
137
|
}
|
|
138
|
+
if (channelItem.membershipType !== "private") {
|
|
139
|
+
return Promise.reject(`The specified channel is not a private channel`);
|
|
140
|
+
}
|
|
138
141
|
return Promise.resolve(channelItem.id);
|
|
139
142
|
});
|
|
140
143
|
}
|
|
@@ -103,6 +103,9 @@ class TeamsChannelMemberSetCommand extends GraphCommand_1.default {
|
|
|
103
103
|
if (!channelItem) {
|
|
104
104
|
return Promise.reject(`The specified channel does not exist in the Microsoft Teams team`);
|
|
105
105
|
}
|
|
106
|
+
if (channelItem.membershipType !== "private") {
|
|
107
|
+
return Promise.reject(`The specified channel is not a private channel`);
|
|
108
|
+
}
|
|
106
109
|
return Promise.resolve(channelItem.id);
|
|
107
110
|
});
|
|
108
111
|
}
|
|
@@ -33,7 +33,7 @@ class TeamsChatGetCommand extends GraphCommand_1.default {
|
|
|
33
33
|
}
|
|
34
34
|
commandAction(logger, args, cb) {
|
|
35
35
|
this
|
|
36
|
-
.getChatId(
|
|
36
|
+
.getChatId(args)
|
|
37
37
|
.then(chatId => this.getChatDetailsById(chatId))
|
|
38
38
|
.then((chat) => {
|
|
39
39
|
logger.log(chat);
|
|
@@ -83,14 +83,14 @@ class TeamsChatGetCommand extends GraphCommand_1.default {
|
|
|
83
83
|
}
|
|
84
84
|
return true;
|
|
85
85
|
}
|
|
86
|
-
getChatId(
|
|
86
|
+
getChatId(args) {
|
|
87
87
|
return __awaiter(this, void 0, void 0, function* () {
|
|
88
88
|
if (args.options.id) {
|
|
89
89
|
return args.options.id;
|
|
90
90
|
}
|
|
91
91
|
return args.options.participants
|
|
92
|
-
? this.getChatIdByParticipants(args.options.participants
|
|
93
|
-
: this.getChatIdByName(args.options.name
|
|
92
|
+
? this.getChatIdByParticipants(args.options.participants)
|
|
93
|
+
: this.getChatIdByName(args.options.name);
|
|
94
94
|
});
|
|
95
95
|
}
|
|
96
96
|
getChatDetailsById(id) {
|
|
@@ -105,11 +105,11 @@ class TeamsChatGetCommand extends GraphCommand_1.default {
|
|
|
105
105
|
return request_1.default.get(requestOptions);
|
|
106
106
|
});
|
|
107
107
|
}
|
|
108
|
-
getChatIdByParticipants(participantsString
|
|
108
|
+
getChatIdByParticipants(participantsString) {
|
|
109
109
|
return __awaiter(this, void 0, void 0, function* () {
|
|
110
110
|
const participants = chatUtil_1.chatUtil.convertParticipantStringToArray(participantsString);
|
|
111
111
|
const currentUserEmail = accessToken_1.accessToken.getUserNameFromAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken).toLowerCase();
|
|
112
|
-
const existingChats = yield chatUtil_1.chatUtil.findExistingChatsByParticipants([currentUserEmail, ...participants]
|
|
112
|
+
const existingChats = yield chatUtil_1.chatUtil.findExistingChatsByParticipants([currentUserEmail, ...participants]);
|
|
113
113
|
if (!existingChats || existingChats.length === 0) {
|
|
114
114
|
throw new Error('No chat conversation was found with these participants.');
|
|
115
115
|
}
|
|
@@ -122,9 +122,9 @@ class TeamsChatGetCommand extends GraphCommand_1.default {
|
|
|
122
122
|
throw new Error(`Multiple chat conversations with these participants found. Please disambiguate:${os.EOL}${disambiguationText}`);
|
|
123
123
|
});
|
|
124
124
|
}
|
|
125
|
-
getChatIdByName(name
|
|
125
|
+
getChatIdByName(name) {
|
|
126
126
|
return __awaiter(this, void 0, void 0, function* () {
|
|
127
|
-
const existingChats = yield chatUtil_1.chatUtil.findExistingGroupChatsByName(name
|
|
127
|
+
const existingChats = yield chatUtil_1.chatUtil.findExistingGroupChatsByName(name);
|
|
128
128
|
if (!existingChats || existingChats.length === 0) {
|
|
129
129
|
throw new Error('No chat conversation was found with this name.');
|
|
130
130
|
}
|
|
@@ -17,7 +17,7 @@ class TeamsChatListCommand extends GraphCommand_1.default {
|
|
|
17
17
|
const filter = args.options.type !== undefined ? `?$filter=chatType eq '${args.options.type}'` : '';
|
|
18
18
|
const endpoint = `${this.resource}/v1.0/chats${filter}`;
|
|
19
19
|
utils_1.odata
|
|
20
|
-
.getAllItems(endpoint
|
|
20
|
+
.getAllItems(endpoint)
|
|
21
21
|
.then((items) => {
|
|
22
22
|
logger.log(items);
|
|
23
23
|
cb();
|
|
@@ -16,7 +16,7 @@ class TeamsChatMemberListCommand extends GraphCommand_1.default {
|
|
|
16
16
|
commandAction(logger, args, cb) {
|
|
17
17
|
const endpoint = `${this.resource}/v1.0/chats/${args.options.chatId}/members`;
|
|
18
18
|
utils_1.odata
|
|
19
|
-
.getAllItems(endpoint
|
|
19
|
+
.getAllItems(endpoint)
|
|
20
20
|
.then((items) => {
|
|
21
21
|
logger.log(items);
|
|
22
22
|
cb();
|
|
@@ -16,7 +16,7 @@ class TeamsChatMessageListCommand extends GraphCommand_1.default {
|
|
|
16
16
|
commandAction(logger, args, cb) {
|
|
17
17
|
const endpoint = `${this.resource}/v1.0/chats/${args.options.chatId}/messages`;
|
|
18
18
|
utils_1.odata
|
|
19
|
-
.getAllItems(endpoint
|
|
19
|
+
.getAllItems(endpoint)
|
|
20
20
|
.then((items) => {
|
|
21
21
|
if (args.options.output !== 'json') {
|
|
22
22
|
items.forEach(i => {
|
|
@@ -93,15 +93,15 @@ class TeamsChatMessageSendCommand extends GraphCommand_1.default {
|
|
|
93
93
|
return args.options.chatId;
|
|
94
94
|
}
|
|
95
95
|
return args.options.userEmails
|
|
96
|
-
? this.ensureChatIdByUserEmails(args.options.userEmails
|
|
97
|
-
: this.getChatIdByName(args.options.chatName
|
|
96
|
+
? this.ensureChatIdByUserEmails(args.options.userEmails)
|
|
97
|
+
: this.getChatIdByName(args.options.chatName);
|
|
98
98
|
});
|
|
99
99
|
}
|
|
100
|
-
ensureChatIdByUserEmails(userEmailsOption
|
|
100
|
+
ensureChatIdByUserEmails(userEmailsOption) {
|
|
101
101
|
return __awaiter(this, void 0, void 0, function* () {
|
|
102
102
|
const userEmails = chatUtil_1.chatUtil.convertParticipantStringToArray(userEmailsOption);
|
|
103
103
|
const currentUserEmail = utils_1.accessToken.getUserNameFromAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken).toLowerCase();
|
|
104
|
-
const existingChats = yield chatUtil_1.chatUtil.findExistingChatsByParticipants([currentUserEmail, ...userEmails]
|
|
104
|
+
const existingChats = yield chatUtil_1.chatUtil.findExistingChatsByParticipants([currentUserEmail, ...userEmails]);
|
|
105
105
|
if (!existingChats || existingChats.length === 0) {
|
|
106
106
|
const chat = yield this.createConversation([currentUserEmail, ...userEmails]);
|
|
107
107
|
return chat.id;
|
|
@@ -115,9 +115,9 @@ class TeamsChatMessageSendCommand extends GraphCommand_1.default {
|
|
|
115
115
|
throw new Error(`Multiple chat conversations with this name found. Please disambiguate:${os.EOL}${disambiguationText}`);
|
|
116
116
|
});
|
|
117
117
|
}
|
|
118
|
-
getChatIdByName(chatName
|
|
118
|
+
getChatIdByName(chatName) {
|
|
119
119
|
return __awaiter(this, void 0, void 0, function* () {
|
|
120
|
-
const existingChats = yield chatUtil_1.chatUtil.findExistingGroupChatsByName(chatName
|
|
120
|
+
const existingChats = yield chatUtil_1.chatUtil.findExistingGroupChatsByName(chatName);
|
|
121
121
|
if (!existingChats || existingChats.length === 0) {
|
|
122
122
|
throw new Error('No chat conversation was found with this name.');
|
|
123
123
|
}
|
|
@@ -17,12 +17,12 @@ exports.chatUtil = {
|
|
|
17
17
|
* @param expectedMemberEmails a string array of participant emailaddresses
|
|
18
18
|
* @param logger a logger to pipe into the graph request odata helper.
|
|
19
19
|
*/
|
|
20
|
-
findExistingChatsByParticipants(expectedMemberEmails
|
|
20
|
+
findExistingChatsByParticipants(expectedMemberEmails) {
|
|
21
21
|
return __awaiter(this, void 0, void 0, function* () {
|
|
22
22
|
const chatType = expectedMemberEmails.length === 2 ? 'oneOnOne' : 'group';
|
|
23
23
|
const endpoint = `https://graph.microsoft.com/v1.0/chats?$filter=chatType eq '${chatType}'&$expand=members&$select=id,topic,createdDateTime,members`;
|
|
24
24
|
const foundChats = [];
|
|
25
|
-
const chats = yield odata_1.odata.getAllItems(endpoint
|
|
25
|
+
const chats = yield odata_1.odata.getAllItems(endpoint);
|
|
26
26
|
for (const chat of chats) {
|
|
27
27
|
const chatMembers = chat.members;
|
|
28
28
|
if (chatMembers.length === expectedMemberEmails.length) {
|
|
@@ -40,10 +40,10 @@ exports.chatUtil = {
|
|
|
40
40
|
* @param name the name of the chat conversation to find
|
|
41
41
|
* @param logger a logger to pipe into the graph request odata helper.
|
|
42
42
|
*/
|
|
43
|
-
findExistingGroupChatsByName(name
|
|
43
|
+
findExistingGroupChatsByName(name) {
|
|
44
44
|
return __awaiter(this, void 0, void 0, function* () {
|
|
45
45
|
const endpoint = `https://graph.microsoft.com/v1.0/chats?$filter=topic eq '${encodeURIComponent(name).replace("'", "''")}'&$expand=members&$select=id,topic,createdDateTime,chatType`;
|
|
46
|
-
return odata_1.odata.getAllItems(endpoint
|
|
46
|
+
return odata_1.odata.getAllItems(endpoint);
|
|
47
47
|
});
|
|
48
48
|
},
|
|
49
49
|
/**
|
|
@@ -17,7 +17,7 @@ class TeamsMessageListCommand extends GraphCommand_1.default {
|
|
|
17
17
|
const deltaExtension = args.options.since !== undefined ? `/delta?$filter=lastModifiedDateTime gt ${args.options.since}` : '';
|
|
18
18
|
const endpoint = `${this.resource}/v1.0/teams/${args.options.teamId}/channels/${args.options.channelId}/messages${deltaExtension}`;
|
|
19
19
|
utils_1.odata
|
|
20
|
-
.getAllItems(endpoint
|
|
20
|
+
.getAllItems(endpoint)
|
|
21
21
|
.then((items) => {
|
|
22
22
|
if (args.options.output !== 'json') {
|
|
23
23
|
items.forEach(i => {
|
|
@@ -16,7 +16,7 @@ class TeamsMessageReplyListCommand extends GraphCommand_1.default {
|
|
|
16
16
|
commandAction(logger, args, cb) {
|
|
17
17
|
const endpoint = `${this.resource}/v1.0/teams/${args.options.teamId}/channels/${args.options.channelId}/messages/${args.options.messageId}/replies`;
|
|
18
18
|
utils_1.odata
|
|
19
|
-
.getAllItems(endpoint
|
|
19
|
+
.getAllItems(endpoint)
|
|
20
20
|
.then((items) => {
|
|
21
21
|
if (args.options.output !== 'json') {
|
|
22
22
|
items.forEach(i => {
|
|
@@ -16,7 +16,7 @@ class TeamsTabListCommand extends GraphCommand_1.default {
|
|
|
16
16
|
commandAction(logger, args, cb) {
|
|
17
17
|
const endpoint = `${this.resource}/v1.0/teams/${args.options.teamId}/channels/${encodeURIComponent(args.options.channelId)}/tabs?$expand=teamsApp`;
|
|
18
18
|
utils_1.odata
|
|
19
|
-
.getAllItems(endpoint
|
|
19
|
+
.getAllItems(endpoint)
|
|
20
20
|
.then((items) => {
|
|
21
21
|
items.forEach(i => {
|
|
22
22
|
i.teamsAppTabId = i.teamsApp.id;
|
|
@@ -22,7 +22,7 @@ class TeamsTeamListCommand extends GraphCommand_1.default {
|
|
|
22
22
|
endpoint = `${this.resource}/v1.0/me/joinedTeams`;
|
|
23
23
|
}
|
|
24
24
|
utils_1.odata
|
|
25
|
-
.getAllItems(endpoint
|
|
25
|
+
.getAllItems(endpoint)
|
|
26
26
|
.then((items) => {
|
|
27
27
|
if (args.options.joined) {
|
|
28
28
|
return Promise.resolve(items);
|
|
@@ -24,7 +24,7 @@ class TeamsUserAppListCommand extends GraphCommand_1.default {
|
|
|
24
24
|
.then((_userId) => {
|
|
25
25
|
userId = _userId.value;
|
|
26
26
|
const endpoint = `${this.resource}/v1.0/users/${encodeURIComponent(userId)}/teamwork/installedApps?$expand=teamsAppDefinition`;
|
|
27
|
-
return utils_1.odata.getAllItems(endpoint
|
|
27
|
+
return utils_1.odata.getAllItems(endpoint);
|
|
28
28
|
})
|
|
29
29
|
.then((items) => {
|
|
30
30
|
items.forEach(i => {
|
|
@@ -42,7 +42,7 @@ class TeamsUserListCommand extends GraphCommand_1.default {
|
|
|
42
42
|
}
|
|
43
43
|
getOwners(logger, groupId) {
|
|
44
44
|
const endpoint = `${this.resource}/v1.0/groups/${groupId}/owners?$select=id,displayName,userPrincipalName,userType`;
|
|
45
|
-
return utils_1.odata.getAllItems(endpoint
|
|
45
|
+
return utils_1.odata.getAllItems(endpoint).then((items) => {
|
|
46
46
|
this.items = this.items.concat(items);
|
|
47
47
|
// Currently there is a bug in the Microsoft Graph that returns Owners as
|
|
48
48
|
// userType 'member'. We therefore update all returned user as owner
|
|
@@ -53,7 +53,7 @@ class TeamsUserListCommand extends GraphCommand_1.default {
|
|
|
53
53
|
}
|
|
54
54
|
getMembersAndGuests(logger, groupId) {
|
|
55
55
|
const endpoint = `${this.resource}/v1.0/groups/${groupId}/members?$select=id,displayName,userPrincipalName,userType`;
|
|
56
|
-
return utils_1.odata.getAllItems(endpoint
|
|
56
|
+
return utils_1.odata.getAllItems(endpoint);
|
|
57
57
|
}
|
|
58
58
|
options() {
|
|
59
59
|
const options = [
|
package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-healthissue-list.js
CHANGED
|
@@ -19,7 +19,7 @@ class TenantServiceAnnouncementHealthIssueListCommand extends GraphCommand_1.def
|
|
|
19
19
|
endpoint += `?$filter=service eq '${encodeURIComponent(args.options.service)}'`;
|
|
20
20
|
}
|
|
21
21
|
utils_1.odata
|
|
22
|
-
.getAllItems(endpoint
|
|
22
|
+
.getAllItems(endpoint)
|
|
23
23
|
.then((items) => {
|
|
24
24
|
logger.log(items);
|
|
25
25
|
cb();
|
|
@@ -19,7 +19,7 @@ class TenantServiceAnnouncementMessageListCommand extends GraphCommand_1.default
|
|
|
19
19
|
endpoint += `?$filter=services/any(c:c+eq+'${encodeURIComponent(args.options.service)}')`;
|
|
20
20
|
}
|
|
21
21
|
utils_1.odata
|
|
22
|
-
.getAllItems(endpoint
|
|
22
|
+
.getAllItems(endpoint)
|
|
23
23
|
.then((items) => {
|
|
24
24
|
logger.log(items);
|
|
25
25
|
cb();
|