@pnp/cli-microsoft365 5.2.0 → 5.3.0-beta.4033f50
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/.eslintrc.js +1 -0
- package/dist/m365/aad/commands/app/app-add.js +1 -1
- package/dist/m365/aad/commands/app/app-role-list.js +1 -1
- package/dist/m365/aad/commands/approleassignment/approleassignment-list.js +55 -22
- 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/aad/commands.js +1 -1
- package/dist/m365/app/commands/app-open.js +64 -0
- package/dist/m365/app/commands.js +1 -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 +186 -0
- package/dist/m365/planner/commands/bucket/bucket-list.js +10 -19
- package/dist/m365/planner/commands/bucket/bucket-remove.js +202 -0
- 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 +138 -7
- package/dist/m365/planner/commands/task/task-list.js +15 -24
- package/dist/m365/planner/commands/task/task-set.js +9 -18
- package/dist/m365/planner/commands.js +2 -0
- package/dist/m365/pp/commands/managementapp/managementapp-list.js +1 -1
- package/dist/m365/spo/commands/field/field-list.js +84 -0
- package/dist/m365/spo/commands/list/list-roleinheritance-break.js +84 -0
- package/dist/m365/spo/commands/list/list-roleinheritance-reset.js +76 -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/roledefinition/roledefinition-list.js +49 -0
- package/dist/m365/spo/commands.js +6 -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-list.js +1 -1
- 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/security/security-alerts-list.js +71 -0
- 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/tenant/commands.js +1 -0
- 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/odata.js +2 -2
- package/dist/utils/planner.js +65 -0
- package/docs/docs/cmd/app/app-open.md +45 -0
- package/docs/docs/cmd/planner/bucket/bucket-get.md +57 -0
- package/docs/docs/cmd/planner/bucket/bucket-remove.md +60 -0
- package/docs/docs/cmd/planner/task/task-get.md +30 -3
- package/docs/docs/cmd/spo/field/field-list.md +51 -0
- package/docs/docs/cmd/spo/list/list-roleinheritance-break.md +55 -0
- package/docs/docs/cmd/spo/list/list-roleinheritance-reset.md +36 -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/roledefinition/roledefinition-list.md +24 -0
- package/docs/docs/cmd/teams/channel/channel-member-list.md +4 -4
- package/docs/docs/cmd/teams/channel/channel-member-remove.md +2 -2
- package/docs/docs/cmd/teams/channel/channel-member-set.md +2 -2
- package/docs/docs/cmd/tenant/security/security-alerts-list.md +30 -0
- package/npm-shrinkwrap.json +1517 -1284
- package/package.json +25 -25
package/.eslintrc.js
CHANGED
|
@@ -325,7 +325,7 @@ class AadAppAddCommand extends GraphCommand_1.default {
|
|
|
325
325
|
logger.logToStderr('Resolving requested APIs...');
|
|
326
326
|
}
|
|
327
327
|
return utils_1.odata
|
|
328
|
-
.getAllItems(`${this.resource}/v1.0/myorganization/servicePrincipals?$select=servicePrincipalNames,appId,oauth2PermissionScopes,appRoles
|
|
328
|
+
.getAllItems(`${this.resource}/v1.0/myorganization/servicePrincipals?$select=servicePrincipalNames,appId,oauth2PermissionScopes,appRoles`)
|
|
329
329
|
.then(servicePrincipals => {
|
|
330
330
|
try {
|
|
331
331
|
const resolvedApis = this.getRequiredResourceAccessForApis(servicePrincipals, args.options.apisDelegated, 'Scope', logger);
|
|
@@ -24,7 +24,7 @@ class AadAppRoleListCommand extends GraphCommand_1.default {
|
|
|
24
24
|
commandAction(logger, args, cb) {
|
|
25
25
|
this
|
|
26
26
|
.getAppObjectId(args, logger)
|
|
27
|
-
.then(objectId => utils_1.odata.getAllItems(`${this.resource}/v1.0/myorganization/applications/${objectId}/appRoles
|
|
27
|
+
.then(objectId => utils_1.odata.getAllItems(`${this.resource}/v1.0/myorganization/applications/${objectId}/appRoles`))
|
|
28
28
|
.then(appRoles => {
|
|
29
29
|
logger.log(appRoles);
|
|
30
30
|
cb();
|
|
@@ -22,29 +22,14 @@ class AadAppRoleAssignmentListCommand extends GraphCommand_1.default {
|
|
|
22
22
|
return ['resourceDisplayName', 'roleName'];
|
|
23
23
|
}
|
|
24
24
|
commandAction(logger, args, cb) {
|
|
25
|
-
let
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
spMatchQuery = `appId eq '${encodeURIComponent(args.options.appId)}'`;
|
|
30
|
-
}
|
|
31
|
-
else if (args.options.objectId) {
|
|
32
|
-
spMatchQuery = `id eq '${encodeURIComponent(args.options.objectId)}'`;
|
|
33
|
-
}
|
|
34
|
-
else {
|
|
35
|
-
spMatchQuery = `displayName eq '${encodeURIComponent(args.options.displayName)}'`;
|
|
36
|
-
}
|
|
37
|
-
this
|
|
38
|
-
.getServicePrincipalForApp(spMatchQuery)
|
|
39
|
-
.then((resp) => {
|
|
40
|
-
if (!resp.value.length) {
|
|
41
|
-
return Promise.reject('app registration not found');
|
|
42
|
-
}
|
|
43
|
-
sp = resp.value[0];
|
|
25
|
+
let spAppRoleAssignments;
|
|
26
|
+
this.getAppRoleAssignments(args.options)
|
|
27
|
+
.then((appRoleAssignments) => {
|
|
28
|
+
spAppRoleAssignments = appRoleAssignments;
|
|
44
29
|
// the role assignment has an appRoleId but no name. To get the name,
|
|
45
30
|
// we need to get all the roles from the resource. the resource is
|
|
46
31
|
// a service principal. Multiple roles may have same resource id.
|
|
47
|
-
const resourceIds =
|
|
32
|
+
const resourceIds = appRoleAssignments.map((item) => item.resourceId);
|
|
48
33
|
const tasks = [];
|
|
49
34
|
for (let i = 0; i < resourceIds.length; i++) {
|
|
50
35
|
tasks.push(this.getServicePrincipal(resourceIds[i]));
|
|
@@ -55,7 +40,7 @@ class AadAppRoleAssignmentListCommand extends GraphCommand_1.default {
|
|
|
55
40
|
// loop through all appRoleAssignments for the servicePrincipal
|
|
56
41
|
// and lookup the appRole.Id in the resources[resourceId].appRoles array...
|
|
57
42
|
const results = [];
|
|
58
|
-
|
|
43
|
+
spAppRoleAssignments.map((appRoleAssignment) => {
|
|
59
44
|
const resource = resources.find((r) => r.id === appRoleAssignment.resourceId);
|
|
60
45
|
if (resource) {
|
|
61
46
|
const appRole = resource.appRoles.find((r) => r.id === appRoleAssignment.appRoleId);
|
|
@@ -65,7 +50,9 @@ class AadAppRoleAssignmentListCommand extends GraphCommand_1.default {
|
|
|
65
50
|
resourceDisplayName: appRoleAssignment.resourceDisplayName,
|
|
66
51
|
resourceId: appRoleAssignment.resourceId,
|
|
67
52
|
roleId: appRole.id,
|
|
68
|
-
roleName: appRole.value
|
|
53
|
+
roleName: appRole.value,
|
|
54
|
+
created: appRoleAssignment.createdDateTime,
|
|
55
|
+
deleted: appRoleAssignment.deletedDateTime
|
|
69
56
|
});
|
|
70
57
|
}
|
|
71
58
|
}
|
|
@@ -74,6 +61,52 @@ class AadAppRoleAssignmentListCommand extends GraphCommand_1.default {
|
|
|
74
61
|
cb();
|
|
75
62
|
}, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
|
|
76
63
|
}
|
|
64
|
+
getAppRoleAssignments(argOptions) {
|
|
65
|
+
return new Promise((resolve, reject) => {
|
|
66
|
+
if (argOptions.objectId) {
|
|
67
|
+
this.getSPAppRoleAssignments(argOptions.objectId)
|
|
68
|
+
.then((spAppRoleAssignments) => {
|
|
69
|
+
if (!spAppRoleAssignments.value.length) {
|
|
70
|
+
reject('no app role assignments found');
|
|
71
|
+
}
|
|
72
|
+
resolve(spAppRoleAssignments.value);
|
|
73
|
+
})
|
|
74
|
+
.catch((err) => {
|
|
75
|
+
reject(err);
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
// Use existing way to get service principal object
|
|
80
|
+
let spMatchQuery = '';
|
|
81
|
+
if (argOptions.appId) {
|
|
82
|
+
spMatchQuery = `appId eq '${encodeURIComponent(argOptions.appId)}'`;
|
|
83
|
+
}
|
|
84
|
+
else {
|
|
85
|
+
spMatchQuery = `displayName eq '${encodeURIComponent(argOptions.displayName)}'`;
|
|
86
|
+
}
|
|
87
|
+
this.getServicePrincipalForApp(spMatchQuery)
|
|
88
|
+
.then((resp) => {
|
|
89
|
+
if (!resp.value.length) {
|
|
90
|
+
reject('app registration not found');
|
|
91
|
+
}
|
|
92
|
+
resolve(resp.value[0].appRoleAssignments);
|
|
93
|
+
})
|
|
94
|
+
.catch((err) => {
|
|
95
|
+
reject(err);
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
getSPAppRoleAssignments(spId) {
|
|
101
|
+
const spRequestOptions = {
|
|
102
|
+
url: `${this.resource}/v1.0/servicePrincipals/${spId}/appRoleAssignments`,
|
|
103
|
+
headers: {
|
|
104
|
+
accept: 'application/json'
|
|
105
|
+
},
|
|
106
|
+
responseType: 'json'
|
|
107
|
+
};
|
|
108
|
+
return request_1.default.get(spRequestOptions);
|
|
109
|
+
}
|
|
77
110
|
getServicePrincipalForApp(filterParam) {
|
|
78
111
|
const spRequestOptions = {
|
|
79
112
|
url: `${this.resource}/v1.0/servicePrincipals?$expand=appRoleAssignments&$filter=${filterParam}`,
|
|
@@ -21,7 +21,7 @@ class AadGroupListCommand extends GraphCommand_1.default {
|
|
|
21
21
|
commandAction(logger, args, cb) {
|
|
22
22
|
const endpoint = args.options.deleted ? 'directory/deletedItems/microsoft.graph.group' : 'groups';
|
|
23
23
|
utils_1.odata
|
|
24
|
-
.getAllItems(`${this.resource}/v1.0/${endpoint}
|
|
24
|
+
.getAllItems(`${this.resource}/v1.0/${endpoint}`)
|
|
25
25
|
.then((groups) => {
|
|
26
26
|
if (args.options.output === 'text') {
|
|
27
27
|
groups.forEach((group) => {
|
|
@@ -15,7 +15,7 @@ class AadGroupSettingListCommand extends GraphCommand_1.default {
|
|
|
15
15
|
}
|
|
16
16
|
commandAction(logger, args, cb) {
|
|
17
17
|
utils_1.odata
|
|
18
|
-
.getAllItems(`${this.resource}/v1.0/groupSettings
|
|
18
|
+
.getAllItems(`${this.resource}/v1.0/groupSettings`)
|
|
19
19
|
.then((groupSettings) => {
|
|
20
20
|
logger.log(groupSettings);
|
|
21
21
|
cb();
|
|
@@ -19,7 +19,7 @@ class AadGroupSettingTemplateGetCommand extends GraphCommand_1.default {
|
|
|
19
19
|
}
|
|
20
20
|
commandAction(logger, args, cb) {
|
|
21
21
|
utils_1.odata
|
|
22
|
-
.getAllItems(`${this.resource}/v1.0/groupSettingTemplates
|
|
22
|
+
.getAllItems(`${this.resource}/v1.0/groupSettingTemplates`)
|
|
23
23
|
.then((templates) => {
|
|
24
24
|
const groupSettingTemplate = templates.filter(t => args.options.id ? t.id === args.options.id : t.displayName === args.options.displayName);
|
|
25
25
|
if (groupSettingTemplate && groupSettingTemplate.length > 0) {
|
|
@@ -15,7 +15,7 @@ class AadGroupSettingTemplateListCommand extends GraphCommand_1.default {
|
|
|
15
15
|
}
|
|
16
16
|
commandAction(logger, args, cb) {
|
|
17
17
|
utils_1.odata
|
|
18
|
-
.getAllItems(`${this.resource}/v1.0/groupSettingTemplates
|
|
18
|
+
.getAllItems(`${this.resource}/v1.0/groupSettingTemplates`)
|
|
19
19
|
.then((templates) => {
|
|
20
20
|
logger.log(templates);
|
|
21
21
|
cb();
|
|
@@ -15,7 +15,7 @@ class AadO365GroupConversationListCommand extends GraphCommand_1.default {
|
|
|
15
15
|
}
|
|
16
16
|
commandAction(logger, args, cb) {
|
|
17
17
|
utils_1.odata
|
|
18
|
-
.getAllItems(`${this.resource}/v1.0/groups/${args.options.groupId}/conversations
|
|
18
|
+
.getAllItems(`${this.resource}/v1.0/groups/${args.options.groupId}/conversations`)
|
|
19
19
|
.then((conversations) => {
|
|
20
20
|
logger.log(conversations);
|
|
21
21
|
cb();
|
|
@@ -24,7 +24,7 @@ class AadO365GroupConversationPostListCommand extends GraphCommand_1.default {
|
|
|
24
24
|
this
|
|
25
25
|
.getGroupId(args)
|
|
26
26
|
.then((retrievedgroupId) => {
|
|
27
|
-
return utils_1.odata.getAllItems(`${this.resource}/v1.0/groups/${retrievedgroupId}/threads/${args.options.threadId}/posts
|
|
27
|
+
return utils_1.odata.getAllItems(`${this.resource}/v1.0/groups/${retrievedgroupId}/threads/${args.options.threadId}/posts`);
|
|
28
28
|
})
|
|
29
29
|
.then((posts) => {
|
|
30
30
|
logger.log(posts);
|
|
@@ -19,7 +19,7 @@ class AadO365GroupRecycleBinItemClearCommand extends GraphCommand_1.default {
|
|
|
19
19
|
}
|
|
20
20
|
commandAction(logger, args, cb) {
|
|
21
21
|
const clearO365GroupRecycleBinItems = () => {
|
|
22
|
-
this.processRecycleBinItemsClear(
|
|
22
|
+
this.processRecycleBinItemsClear().then(_ => cb(), (rawRes) => this.handleRejectedODataJsonPromise(rawRes, logger, cb));
|
|
23
23
|
};
|
|
24
24
|
if (args.options.confirm) {
|
|
25
25
|
clearO365GroupRecycleBinItems();
|
|
@@ -40,12 +40,12 @@ class AadO365GroupRecycleBinItemClearCommand extends GraphCommand_1.default {
|
|
|
40
40
|
});
|
|
41
41
|
}
|
|
42
42
|
}
|
|
43
|
-
processRecycleBinItemsClear(
|
|
43
|
+
processRecycleBinItemsClear() {
|
|
44
44
|
const filter = `?$filter=groupTypes/any(c:c+eq+'Unified')`;
|
|
45
45
|
const topCount = '&$top=100';
|
|
46
46
|
const endpoint = `${this.resource}/v1.0/directory/deletedItems/Microsoft.Graph.Group${filter}${topCount}`;
|
|
47
47
|
return utils_1.odata
|
|
48
|
-
.getAllItems(endpoint
|
|
48
|
+
.getAllItems(endpoint)
|
|
49
49
|
.then((recycleBinItems) => {
|
|
50
50
|
if (recycleBinItems.length === 0) {
|
|
51
51
|
return Promise.resolve();
|
|
@@ -26,7 +26,7 @@ class AadO365GroupRecycleBinItemListCommand extends GraphCommand_1.default {
|
|
|
26
26
|
const topCount = '&$top=100';
|
|
27
27
|
const endpoint = `${this.resource}/v1.0/directory/deletedItems/Microsoft.Graph.Group${filter}${displayNameFilter}${mailNicknameFilter}${topCount}`;
|
|
28
28
|
utils_1.odata
|
|
29
|
-
.getAllItems(endpoint
|
|
29
|
+
.getAllItems(endpoint)
|
|
30
30
|
.then((recycleBinItems) => {
|
|
31
31
|
logger.log(recycleBinItems);
|
|
32
32
|
cb();
|
|
@@ -38,7 +38,7 @@ class AadO365GroupUserListCommand extends GraphCommand_1.default {
|
|
|
38
38
|
getOwners(logger, groupId) {
|
|
39
39
|
const endpoint = `${this.resource}/v1.0/groups/${groupId}/owners?$select=id,displayName,userPrincipalName,userType`;
|
|
40
40
|
return utils_1.odata
|
|
41
|
-
.getAllItems(endpoint
|
|
41
|
+
.getAllItems(endpoint)
|
|
42
42
|
.then(users => {
|
|
43
43
|
// Currently there is a bug in the Microsoft Graph that returns Owners as
|
|
44
44
|
// userType 'member'. We therefore update all returned user as owner
|
|
@@ -50,7 +50,7 @@ class AadO365GroupUserListCommand extends GraphCommand_1.default {
|
|
|
50
50
|
}
|
|
51
51
|
getMembersAndGuests(logger, groupId) {
|
|
52
52
|
const endpoint = `${this.resource}/v1.0/groups/${groupId}/members?$select=id,displayName,userPrincipalName,userType`;
|
|
53
|
-
return utils_1.odata.getAllItems(endpoint
|
|
53
|
+
return utils_1.odata.getAllItems(endpoint);
|
|
54
54
|
}
|
|
55
55
|
options() {
|
|
56
56
|
const options = [
|
|
@@ -92,7 +92,7 @@ class AadO365GroupUserSetCommand extends GraphCommand_1.default {
|
|
|
92
92
|
getOwners(logger, groupId) {
|
|
93
93
|
const endpoint = `${this.resource}/v1.0/groups/${groupId}/owners?$select=id,displayName,userPrincipalName,userType`;
|
|
94
94
|
return utils_1.odata
|
|
95
|
-
.getAllItems(endpoint
|
|
95
|
+
.getAllItems(endpoint)
|
|
96
96
|
.then(users => {
|
|
97
97
|
// Currently there is a bug in the Microsoft Graph that returns Owners as
|
|
98
98
|
// userType 'member'. We therefore update all returned user as owner
|
|
@@ -104,7 +104,7 @@ class AadO365GroupUserSetCommand extends GraphCommand_1.default {
|
|
|
104
104
|
}
|
|
105
105
|
getMembersAndGuests(logger, groupId) {
|
|
106
106
|
const endpoint = `${this.resource}/v1.0/groups/${groupId}/members?$select=id,displayName,userPrincipalName,userType`;
|
|
107
|
-
return utils_1.odata.getAllItems(endpoint
|
|
107
|
+
return utils_1.odata.getAllItems(endpoint);
|
|
108
108
|
}
|
|
109
109
|
options() {
|
|
110
110
|
const options = [
|
|
@@ -27,7 +27,7 @@ class AadUserListCommand extends GraphCommand_1.default {
|
|
|
27
27
|
const endpoint = args.options.deleted ? 'directory/deletedItems/microsoft.graph.user' : 'users';
|
|
28
28
|
const url = `${this.resource}/v1.0/${endpoint}?$select=${properties.join(',')}${(filter.length > 0 ? '&' + filter : '')}&$top=100`;
|
|
29
29
|
utils_1.odata
|
|
30
|
-
.getAllItems(url
|
|
30
|
+
.getAllItems(url)
|
|
31
31
|
.then((users) => {
|
|
32
32
|
logger.log(users);
|
|
33
33
|
cb();
|
|
@@ -6,11 +6,11 @@ exports.default = {
|
|
|
6
6
|
APP_DELETE: `${prefix} app delete`,
|
|
7
7
|
APP_GET: `${prefix} app get`,
|
|
8
8
|
APP_REMOVE: `${prefix} app remove`,
|
|
9
|
-
APP_SET: `${prefix} app set`,
|
|
10
9
|
APP_ROLE_ADD: `${prefix} app role add`,
|
|
11
10
|
APP_ROLE_DELETE: `${prefix} app role delete`,
|
|
12
11
|
APP_ROLE_LIST: `${prefix} app role list`,
|
|
13
12
|
APP_ROLE_REMOVE: `${prefix} app role remove`,
|
|
13
|
+
APP_SET: `${prefix} app set`,
|
|
14
14
|
APPROLEASSIGNMENT_ADD: `${prefix} approleassignment add`,
|
|
15
15
|
APPROLEASSIGNMENT_LIST: `${prefix} approleassignment list`,
|
|
16
16
|
APPROLEASSIGNMENT_REMOVE: `${prefix} approleassignment remove`,
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const cli_1 = require("../../../cli");
|
|
4
|
+
const validation_1 = require("../../../utils/validation");
|
|
5
|
+
const settingsNames_1 = require("../../../settingsNames");
|
|
6
|
+
const AppCommand_1 = require("../../base/AppCommand");
|
|
7
|
+
const commands_1 = require("../commands");
|
|
8
|
+
class AppOpenCommand extends AppCommand_1.default {
|
|
9
|
+
get name() {
|
|
10
|
+
return commands_1.default.OPEN;
|
|
11
|
+
}
|
|
12
|
+
get description() {
|
|
13
|
+
return 'Opens Azure AD app in the Azure AD portal';
|
|
14
|
+
}
|
|
15
|
+
getTelemetryProperties(args) {
|
|
16
|
+
const telemetryProps = super.getTelemetryProperties(args);
|
|
17
|
+
telemetryProps.appId = typeof args.options.appId !== 'undefined';
|
|
18
|
+
telemetryProps.preview = typeof args.options.preview !== 'undefined';
|
|
19
|
+
return telemetryProps;
|
|
20
|
+
}
|
|
21
|
+
commandAction(logger, args, cb) {
|
|
22
|
+
this.logOrOpenUrl(args, logger)
|
|
23
|
+
.then(_ => cb(), (rawRes) => this.handleRejectedODataJsonPromise(rawRes, logger, cb));
|
|
24
|
+
}
|
|
25
|
+
logOrOpenUrl(args, logger) {
|
|
26
|
+
return new Promise((resolve, reject) => {
|
|
27
|
+
const previewPrefix = args.options.preview === true ? "preview." : "";
|
|
28
|
+
const url = `https://${previewPrefix}portal.azure.com/#blade/Microsoft_AAD_RegisteredApps/ApplicationMenuBlade/Overview/appId/${this.appId}/isMSAApp/`;
|
|
29
|
+
if (cli_1.Cli.getInstance().getSettingWithDefaultValue(settingsNames_1.settingsNames.autoOpenLinksInBrowser, false) === false) {
|
|
30
|
+
logger.log(`Use a web browser to open the page ${url}`);
|
|
31
|
+
return resolve();
|
|
32
|
+
}
|
|
33
|
+
logger.log(`Opening the following page in your browser: ${url}`);
|
|
34
|
+
// 'open' is required here so we can lazy load the dependency.
|
|
35
|
+
// _open is never set before hitting this line, but this check
|
|
36
|
+
// is implemented so that we can stub it when testing.
|
|
37
|
+
/* c8 ignore next 3 */
|
|
38
|
+
if (!this._open) {
|
|
39
|
+
this._open = require('open');
|
|
40
|
+
}
|
|
41
|
+
this._open(url).then(() => {
|
|
42
|
+
resolve();
|
|
43
|
+
}, (error) => {
|
|
44
|
+
reject(error);
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
options() {
|
|
49
|
+
const options = [
|
|
50
|
+
{ option: '--appId [appId]' },
|
|
51
|
+
{ option: '--preview' }
|
|
52
|
+
];
|
|
53
|
+
const parentOptions = super.options();
|
|
54
|
+
return options.concat(parentOptions);
|
|
55
|
+
}
|
|
56
|
+
validate(args) {
|
|
57
|
+
if (args.options.appId && !validation_1.validation.isValidGuid(args.options.appId)) {
|
|
58
|
+
return `${args.options.appId} is not a valid GUID`;
|
|
59
|
+
}
|
|
60
|
+
return true;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
module.exports = new AppOpenCommand();
|
|
64
|
+
//# sourceMappingURL=app-open.js.map
|
|
@@ -156,7 +156,7 @@ class FileListCommand extends GraphCommand_1.default {
|
|
|
156
156
|
.all(folderIds.map((folderId) =>
|
|
157
157
|
// get items from folder. Because we can't filter out folders here
|
|
158
158
|
// we need to get all items from the folder and filter them out later
|
|
159
|
-
utils_1.odata.getAllItems(`${this.resource}/v1.0/drives/${driveId}/items/${folderId}/children
|
|
159
|
+
utils_1.odata.getAllItems(`${this.resource}/v1.0/drives/${driveId}/items/${folderId}/children`)))
|
|
160
160
|
.then(res => {
|
|
161
161
|
// flatten data from all promises
|
|
162
162
|
files = files.concat(...res);
|
|
@@ -27,7 +27,7 @@ class OutlookMessageListCommand extends GraphCommand_1.default {
|
|
|
27
27
|
.getFolderId(args)
|
|
28
28
|
.then((folderId) => {
|
|
29
29
|
const url = folderId ? `me/mailFolders/${folderId}/messages` : 'me/messages';
|
|
30
|
-
return utils_1.odata.getAllItems(`${this.resource}/v1.0/${url}?$top=50
|
|
30
|
+
return utils_1.odata.getAllItems(`${this.resource}/v1.0/${url}?$top=50`);
|
|
31
31
|
})
|
|
32
32
|
.then((messages) => {
|
|
33
33
|
logger.log(messages);
|
|
@@ -24,7 +24,7 @@ class OutlookRoomListCommand extends GraphCommand_1.default {
|
|
|
24
24
|
endpoint = `${this.resource}/v1.0/places/${args.options.roomlistEmail}/microsoft.graph.roomlist/rooms`;
|
|
25
25
|
}
|
|
26
26
|
utils_1.odata
|
|
27
|
-
.getAllItems(endpoint
|
|
27
|
+
.getAllItems(endpoint)
|
|
28
28
|
.then((rooms) => {
|
|
29
29
|
logger.log(rooms);
|
|
30
30
|
cb();
|
|
@@ -15,7 +15,7 @@ class OutlookRoomListListCommand extends GraphCommand_1.default {
|
|
|
15
15
|
}
|
|
16
16
|
commandAction(logger, args, cb) {
|
|
17
17
|
utils_1.odata
|
|
18
|
-
.getAllItems(`${this.resource}/v1.0/places/microsoft.graph.roomlist
|
|
18
|
+
.getAllItems(`${this.resource}/v1.0/places/microsoft.graph.roomlist`)
|
|
19
19
|
.then((roomLists) => {
|
|
20
20
|
logger.log(roomLists);
|
|
21
21
|
cb();
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const Auth_1 = require("../../../../Auth");
|
|
3
4
|
const request_1 = require("../../../../request");
|
|
4
5
|
const utils_1 = require("../../../../utils");
|
|
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 PlannerBucketAddCommand extends GraphCommand_1.default {
|
|
@@ -24,6 +26,10 @@ class PlannerBucketAddCommand extends GraphCommand_1.default {
|
|
|
24
26
|
return ['id', 'name', 'planId', 'orderHint'];
|
|
25
27
|
}
|
|
26
28
|
commandAction(logger, args, cb) {
|
|
29
|
+
if (utils_1.accessToken.isAppOnlyAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken)) {
|
|
30
|
+
this.handleError('This command does not support application permissions.', logger, cb);
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
27
33
|
this
|
|
28
34
|
.getPlanId(args)
|
|
29
35
|
.then((planId) => {
|
|
@@ -52,22 +58,8 @@ class PlannerBucketAddCommand extends GraphCommand_1.default {
|
|
|
52
58
|
}
|
|
53
59
|
return this
|
|
54
60
|
.getGroupId(args)
|
|
55
|
-
.then(
|
|
56
|
-
|
|
57
|
-
url: `${this.resource}/v1.0/planner/plans?$filter=(owner eq '${groupId}')`,
|
|
58
|
-
headers: {
|
|
59
|
-
accept: 'application/json;odata.metadata=none'
|
|
60
|
-
},
|
|
61
|
-
responseType: 'json'
|
|
62
|
-
};
|
|
63
|
-
return request_1.default.get(requestOptions);
|
|
64
|
-
}).then((response) => {
|
|
65
|
-
const plan = response.value.find(val => val.title === args.options.planName);
|
|
66
|
-
if (!plan) {
|
|
67
|
-
return Promise.reject(`The specified plan does not exist`);
|
|
68
|
-
}
|
|
69
|
-
return Promise.resolve(plan.id);
|
|
70
|
-
});
|
|
61
|
+
.then(groupId => planner_1.planner.getPlanByName(args.options.planName, groupId))
|
|
62
|
+
.then(plan => plan.id);
|
|
71
63
|
}
|
|
72
64
|
getGroupId(args) {
|
|
73
65
|
if (args.options.ownerGroupId) {
|